亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > C > 正文

使用C語言提取子字符串及判斷對稱子字符串最大長度

2020-01-26 14:59:03
字體:
來源:轉載
供稿:網友

先來看一個使用C語言從字符串中提取子字符串的基本方法總結:

#include <stdio.h>/*處理中文字符*//*遍歷字符串,非ASCII字符讀取2個字節,ASCII讀取一個字節,獲取字符串長度*/int StrLenU(const char* string){   int len = 0 ;   const char* p = string;   while(*p++ != '/0')   {     if(*p > 0x80 || *p < 0)     {      p++;     }     len++;   }   return len;}/*遍歷字符串,非ASCII字符讀取2個字節,ASCII讀取一個字節,返回指定位置的字符串指針,默認從1開始*/char* StrSetPosU(const char* string,int pos){   char* result;   result = string;   while (result != NULL && *result != '/0' && pos > 1)   {     if(*result > 0x80 || *result < 0)     {       result++;     }     result++;     pos--;   }   if(pos!=0)     return result;   return '/0';}/*獲取指定內存中的字符串個數,中文字符作為一個字符*/int StrLenMemU(const char* string,int size){     int len = 0 ;   const char* p = string;   while(*p++ != '/0' && size > 0)   {     if(*p > 0x80 || *p < 0)     {      p++;      size--;      }     size-- ;     len++;   }   return len;}/*可取中文字符串,當number為-1等負數時,取從start開始的剩余所有字符,默認從1開始*/char* StringSubU(const char* string,int start,int number){   int len = StrLenU(string) ;   if(start>len)   {     printf("Start %d is too big than string length %d!/n",start,len);     return NULL;   }   int bufsize = 0;   int num = number;   const char* p = string;   const char* start_char =string;   /*重置指針,獲取指定開始位置*/   p = StrSetPosU(string,start);   start_char = p;   /*當取值為負值時,則取全部值*/   if(number < 0)   {     while(*p != '/0')     {      p++;      bufsize++;     }   }   else   {     while(1)     {      /*當指針移到末尾,而且還沒有獲取指定數的字符時,說明此時指定字符數過多,將會取剩下的所有值*/      if(*p == '/0' && num > 0)      {        printf("Number : %d is to big!/n",number);        break;      }      /*當num為0時,說明讀取字符已經滿足要求*/      else if(num ==0 )        break;      /*當字符為ASCII時,*/      if(*p > 0x80 || *p < 0)      {        bufsize++;        p++;      }      bufsize++;      p++;      num--;     }   }   num = bufsize;   /*開始分配內存*/   char* result ;   result = (char*)malloc(sizeof(char)*(bufsize+1));   memset(result,0,sizeof(char)*(bufsize+1));   /*開始復制字符串*/   int i = 0;   int j = 0;   while(num != 0)   {     result[i++] = start_char[j++];     num--;   }   /*尾部置零*/   result[bufsize] = '/0';   return result;}int main(){   /*進行測試*/   char* t = "a哈哈aab和c哈";   printf("length: %d/n",StrLenU("哈哈a哈a哈"));   printf("指向前%s/n指向后:%s/n",t,StrSetPosU(t,3));   printf("全字符時字符個數:%d/n",StrLenMemU(t,6));   printf("半個字符時字符個數:%d/n",StrLenMemU(t,4));    printf("1.正常取值:%s/n",StringSubU("a哈aa哈a",1,2));   printf("2.負值取值:%s/n",StringSubU("a哈aa哈a",-1,2));   printf("3.起始值過大:%s/n",StringSubU("a哈aa哈a",7,2));   printf("4.取值過大:%s/n",StringSubU("a哈aa哈a",5,3));   printf("5.負值取全部:%s/n",StringSubU("a哈aa哈a",4,-1));   return 0;}

判斷對稱子字符串最大長度的方法

判斷回文
先重寫一個判斷回文字串的方法,用指針實現,而不是數組了

  #include <stdio.h>   #include <stdlib.h>   #include <string.h>       void isSymmetrical(char *str)   {     char *begin, *end;     int flag, len = strlen(str);         for (begin = str, end = str + len - 1, flag = 1; begin <= end; begin ++, end --) {       if (*begin != *end) {         flag = 0;         break;       }     }         if (flag)       printf("Yes!/n");     else       printf("No!/n");   }           int main(void)   {     char str[1001];         while (gets(str)) {       isSymmetrical(str);     }         return 0;   }       
/**************************************************************
        Problem: 1192
        User: wangzhengyi
        Language: C
        Result: Accepted
        Time:10 ms
        Memory:912 kb
    ****************************************************************/ 


判斷回文子串
判斷子串是否為回文,可以考慮從內向外比較。例如字符串“google”,如果我們判斷第二個字符o是對稱的,只需要再向左、和向右各移一位就可以判斷下一個字符串是否是對稱的了
需要注意的一點是,針對原字符串中的每一個字符有兩種情況:

    以該字符為中心的對稱分布,也就是回文子串為奇數
    以該字符和該字符前一個字符為中心的對稱分布,也就是說回文子串是偶數


時間復雜度分析:

外層需要n - 1層循環,內層對于每個字符,都由中間向兩邊遍歷一遍,為n,因此總的時間復雜度為O(n * n)

題目

    題目描述: 
    輸入一個字符串,輸出該字符串中對稱的子字符串的最大長度。 
    比如輸入字符串“google”,由于該字符串里最長的對稱子字符串是“goog”,因此輸出4。 
    輸入: 
    存在多組數據,每組數據一行字符串,長度不大于100。 
    輸出: 
    輸出回文子串的最大長度。 
    樣例輸入: 
    google 
    樣例輸出: 
    4 


ac代碼

 

  #include <stdio.h>   #include <string.h>   #include <stdlib.h>       /**    * 最長回文字串的長度    */   void maxSymmetricalSubstring(char *str)   {     int maxlength, len;     char *pre, *next, *current;           current = str + 1;     maxlength = 0;         while (*current != '/0') {       pre = current - 1;       next = current + 1;           while (pre >= str && *next != '/0' && *pre == *next) {         pre --;         next ++;         }           len = (next - 1) - (pre + 1) + 1;               if (len > maxlength) {         maxlength = len;       }           pre = current - 1;       next = current;           while (pre >= str && *next != '/0' && *pre == *next) {         pre --;         next ++;       }       len = (next - 1) - (pre + 1) + 1;           if (len > maxlength) {         maxlength = len;       }           current ++;     }           printf("%d/n", maxlength);   }         int main(void)   {     char str[101];         while (gets(str)) {       maxSymmetricalSubstring(str);     }         return 0;   } 

    /**************************************************************
        Problem: 1252
        User: wangzhengyi
        Language: C
        Result: Accepted
        Time:0 ms
        Memory:912 kb
    ****************************************************************/ 

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲国产第一页| 美女国内精品自产拍在线播放| 久久久久久久久久亚洲| 欧美久久精品午夜青青大伊人| 亚洲精品国产综合区久久久久久久| 亚洲人成电影网站色…| 亚洲第一综合天堂另类专| 亚洲风情亚aⅴ在线发布| 欧美黑人国产人伦爽爽爽| 久久精品影视伊人网| 色哟哟亚洲精品一区二区| zzjj国产精品一区二区| 精品久久久中文| 亚洲国产精品久久久久久| 成人网页在线免费观看| 日韩av第一页| 亚洲精品国产精品国自产观看浪潮| 国内精品视频一区| 亚洲美女视频网站| 久久视频在线视频| 亚洲精品美女在线观看| 91丝袜美腿美女视频网站| 日韩毛片中文字幕| 91在线播放国产| 成人av在线天堂| 欧美视频不卡中文| 国产91久久婷婷一区二区| 欧美日韩一二三四五区| 欧美日韩亚洲视频| 中文字幕久久久| 伦理中文字幕亚洲| 久热爱精品视频线路一| 日日噜噜噜夜夜爽亚洲精品| 国产视频亚洲精品| 久久国内精品一国内精品| 91探花福利精品国产自产在线| 国产午夜精品全部视频播放| 亚洲日本欧美中文幕| 国产成人精品综合| 精品国产91乱高清在线观看| 欧美俄罗斯性视频| 国产亚洲欧洲黄色| 久久久亚洲天堂| 国产精品青草久久久久福利99| 亚洲jizzjizz日本少妇| 欧美成aaa人片免费看| 成人午夜在线影院| 亚洲成人激情在线| 日韩欧美大尺度| 久久国产精品久久久久| 91免费版网站入口| 欧美亚洲激情在线| 日本精品视频在线| 国产成人精品亚洲精品| 人九九综合九九宗合| 欧美人成在线视频| 国产精品久久久久久五月尺| 欧美极品在线视频| 国产精品青草久久久久福利99| 国产精品久久9| 51ⅴ精品国产91久久久久久| 欧美在线免费看| 法国裸体一区二区| 亚洲黄色在线观看| 日韩免费av片在线观看| 国产成人精品视频在线| 亚洲欧美国产一本综合首页| 欧美成人精品影院| 91精品国产综合久久久久久久久| 亚洲第五色综合网| 中文字幕国产亚洲| 性色av一区二区三区在线观看| 米奇精品一区二区三区在线观看| 精品久久久一区| 中文字幕亚洲一区在线观看| 4388成人网| 国产精品免费小视频| 欧美色播在线播放| 欧美日韩黄色大片| 91福利视频网| 国产一区二区三区在线观看视频| 伊人伊成久久人综合网小说| 欧美精品18videos性欧| 91国自产精品中文字幕亚洲| 国产精品久久久久久中文字| 色综合久久88色综合天天看泰| 久久精品人人做人人爽| 久久99久久久久久久噜噜| 色综合男人天堂| 欧美性视频在线| 成人国产精品一区二区| 日韩网站免费观看高清| 91人成网站www| 91久久精品美女高潮| 亚洲成av人片在线观看香蕉| 最近的2019中文字幕免费一页| 国产精品视频yy9099| 夜夜嗨av一区二区三区免费区| 欧美性xxxxxxx| 狠狠操狠狠色综合网| 性欧美在线看片a免费观看| 欧美午夜无遮挡| 中文字幕在线看视频国产欧美| 国产色视频一区| 成人春色激情网| 在线看欧美日韩| 欧美精品免费在线观看| 日韩高清中文字幕| 久久视频免费观看| 97在线免费观看视频| 日韩一区二区福利| 国产精品偷伦一区二区| 欧美日韩一区二区在线| 欧美大尺度激情区在线播放| 日本午夜精品理论片a级appf发布| 成人精品视频久久久久| 91精品国产91久久久久久吃药| 日韩视频免费看| 国外成人性视频| 欧美乱大交做爰xxxⅹ性3| 国产精品va在线播放| 久久视频在线视频| 久久久久久18| 成人高h视频在线| 91久久国产综合久久91精品网站| 国产成人av在线播放| 中文字幕免费国产精品| 欧美在线视频一二三| 亚洲精品视频久久| 欧美视频在线看| 欧美激情xxxxx| 欧美国产精品人人做人人爱| 欧美激情免费视频| 高清亚洲成在人网站天堂| 国产午夜精品一区理论片飘花| 日韩电影免费在线观看| 欧美精品日韩三级| 色播久久人人爽人人爽人人片视av| 久久久久国产精品www| 日韩精品视频免费在线观看| 欧美第一黄色网| 国产精品青草久久久久福利99| 亚洲黄色有码视频| 亚洲大胆人体av| 91久久久在线| 日韩激情视频在线| 中文字幕无线精品亚洲乱码一区| 亚洲aⅴ男人的天堂在线观看| 一区二区亚洲精品国产| 欧美亚洲视频在线看网址| 欧美在线视频网站| 97国产真实伦对白精彩视频8| 91美女片黄在线观| 久久久女女女女999久久| 日韩电影中文字幕在线观看| 久久精品成人欧美大片古装| 欧美一级大片在线观看| 亚洲欧美在线免费观看| 亚洲国产天堂久久国产91| 欧美人与性动交a欧美精品| 中文字幕久热精品在线视频| 青草青草久热精品视频在线观看| 久久综合免费视频影院| 色与欲影视天天看综合网|