青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

面對現實,超越自己
逆水行舟,不進則退
posts - 269,comments - 32,trackbacks - 0
轉自:http://apps.hi.baidu.com/share/detail/6937479

對于類似從給定的文本中,查找其中最長的重復子字符串的問題,可以采用“后綴數組”來高效地完成此任務。后綴數組使用文本本身和n個附加指針(與文本數組相應的指針數組)來表示輸入文本中的n個字符的每個子字符串。
    首先,如果輸入字符串存儲在c[0..n-1]中,那么就可以使用類似于下面的代碼比較每對子字符串:
    maxlen = -1
    for i = [0, n)
        for j = (i, n)
            if (thislen = comlen(&c[i], &c[j])) > maxlen
                maxlen = thislen
                maxi = i
                maxj = j
    當作為comlen函數參數的兩個字符串長度相等時,該函數便返回這個長度值,從第一個字符開始:
    int comlen(char *p, char* q)
        i = 0
        while *p && (*p++ = *q++)
            i++
        return i
    由于該算法查看所有的字符串對,所以它的時間和n的平方成正比。下面便是使用“后綴數組”的解決辦法。
    如果程序至多可以處理MAXN個字符,這些字符被存儲在數組c中:
    #define MAXN 5000000
    char c[MAXN], *a[MAXN];
    在讀取輸入時,首先初始化a,這樣,每個元素就都指向輸入字符串中的相應字符:
    while (ch = getchar()) != EOF
  a[n] = &c[n];
  c[n++] = ch;
 c[n] = 0 //將數組c中的最后一個元素設為空字符,以終止所有字符串。
 這樣,元素a[0]指向整個字符串,下一個元素指向以第二個字符開始的數組的后綴,等等。如若輸入字符串為"banana",該數組將表示這些后綴:
 a[0]:banana
 a[1]:anana
 a[2]:nana
 a[3]:ana
 a[4]:na
 a[5]:a
 由于數組a中的指針分別指向字符串中的每個后綴,所以將數組a命名為"后綴數組"
 第二,對后綴數組進行快速排序,以將后綴相近的(變位詞)子串集中在一起
 qsort(a, n, sizeof(char*), pstrcmp)后
 a[0]:a
 a[1]:ana
 a[2]:anana
 a[3]:banana
 a[4]:na
 a[5]:nana
 第三,使用以下comlen函數對數組進行掃描比較鄰接元素,以找出最長重復的字符串:
 for i = [0, n)
     if comlen(a[i], a[i+1]) > maxlen
         maxlen = comlen(a[i], a[i+1])
         maxi = i
 printf("%.*s/n", maxlen, a[maxi])
 由于少了內層循環,只是多了一次排序,因此該算法的運行時間為O(n logn). 

完整代碼如下:
 1 #include <stdio.h>
 2 #include <stdlib.h>
 3 #include <string.h>
 4 
 5 #define MAXCHAR 5000 //最長處理5000個字符
 6 
 7 char c[MAXCHAR], *a[MAXCHAR];
 8 
 9 int comlen( char *p, char *q )
10 {
11     int i = 0;
12     while*&& (*p++ == *q++) )
13         ++i;
14     return i;
15 }
16 
17 int pstrcmp( const void *p1, const void *p2 )
18 {
19     return strcmp( *(char* const *)p1, *(char* const*)p2 );
20 }
21 
22 int main( )
23 {
24     char ch;
25     int n=0;
26     int i, temp;
27     int maxlen=0, maxi=0;
28     printf("Please input your string:\n");
29     while( (ch=getchar())!='\n' )
30    {
31         a[n]=&c[n];
32         c[n++]=ch;
33     }
34     c[n]='\0';
35     qsort( a, n, sizeof(char*), pstrcmp );
36     for(i=0; i<n-1++i )
37    {
38         temp=comlen( a[i], a[i+1] );
39         if( temp>maxlen )
40         {
41             maxlen=temp;
42             maxi=i;
43         }
44     }
45     printf("%.*s\n",maxlen, a[maxi]);
46     system("PAUSE");
47     return 0;
48 }

posted on 2012-03-30 13:03 王海光 閱讀(743) 評論(0)  編輯 收藏 引用 所屬分類: 算法
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            欧美呦呦网站| 一区二区精品在线| 欧美午夜精品一区二区三区| 国产精品久久久久久久久免费桃花| 伊人成人在线| 久久免费精品视频| 亚洲一级黄色av| 欧美国产综合视频| 国产尤物精品| 午夜精品久久久久久| 一本色道久久综合亚洲二区三区| 欧美日韩在线免费| 一本色道久久综合亚洲精品按摩| 亚洲成色777777女色窝| 久久久国产成人精品| 久久在线视频| 亚洲国产精品第一区二区| 欧美不卡视频一区发布| 免费欧美网站| 激情成人av| 91久久线看在观草草青青| 久久精品一区二区三区中文字幕| 亚洲欧美日韩成人| 国产视频精品xxxx| 欧美成人一二三| 欧美日韩在线视频首页| 欧美一站二站| 国产日韩欧美综合一区| 欧美精品v国产精品v日韩精品 | 欧美日韩亚洲综合一区| 中文国产亚洲喷潮| 亚洲图片你懂的| 亚洲第一区在线| 亚洲欧美日韩区| 欧美三级视频在线播放| 久久9热精品视频| 久久精精品视频| 国产精品久久网站| 免播放器亚洲| 亚洲综合色网站| 亚洲综合日本| 国内外成人免费视频| avtt综合网| 欧美成ee人免费视频| 久久久久久久久久码影片| 亚洲淫性视频| 久久综合狠狠综合久久综合88| 欧美成人在线网站| 久久久久久久一区| 亚洲专区一区| 国产欧美日韩综合| 久久精品国产一区二区电影| 在线视频日韩| 欧美中文字幕视频| 99综合电影在线视频| 欧美高潮视频| 欧美一区二区免费视频| 国产精品视频一| 欧美亚洲视频一区二区| 性久久久久久久| 国产伪娘ts一区| 欧美日韩国产综合视频在线观看| 最新亚洲电影| 久久夜色精品国产| 亚洲欧美日韩一区二区| 在线国产精品一区| 欧美日韩在线不卡| 欧美a一区二区| 久久综合九色综合欧美就去吻| 亚洲一区国产精品| 亚洲视频一区在线观看| 亚洲视频播放| 亚洲欧美日韩人成在线播放| 一本色道久久综合亚洲精品按摩| 国产欧美日韩不卡免费| 香蕉国产精品偷在线观看不卡 | 亚洲日本va午夜在线影院| 亚洲欧洲一区| 欧美成年人在线观看| 亚洲欧美日本在线| 免费一区视频| 午夜视频精品| 国产一级精品aaaaa看| 一区二区三区四区五区精品| 日韩一二在线观看| 欧美另类极品videosbest最新版本| 亚洲国产岛国毛片在线| 国产在线成人| 国产精品久久久久久久9999| 国产一区深夜福利| 亚洲欧美精品一区| 日韩一二三在线视频播| 日韩视频在线观看一区二区| 欧美日韩国产综合一区二区| 欧美激情a∨在线视频播放| 欧美日韩精品三区| 亚洲欧美在线一区| 欧美激情国产日韩| 亚洲综合好骚| 国产精品一区二区欧美| 欧美日韩久久久久久| 欧美亚洲综合久久| 艳女tv在线观看国产一区| 亚洲国产精品美女| 99在线热播精品免费| 久久久精品国产99久久精品芒果| 久久在线免费| 黑人一区二区| 性欧美大战久久久久久久久| 夜夜嗨av一区二区三区中文字幕| 亚洲激情偷拍| 9人人澡人人爽人人精品| 久久精品中文| 国产一区二区三区四区在线观看| 亚洲美女电影在线| 欧美国产一区视频在线观看| 性8sex亚洲区入口| 国产精品免费观看视频| 一区二区三区国产在线| 亚洲国产精彩中文乱码av在线播放| 亚洲欧美伊人| 在线观看视频一区二区欧美日韩| 亚洲黄色一区| 欧美激情国产日韩精品一区18| 久久精品视频在线播放| 极品av少妇一区二区| 久久国产精品一区二区| 国产精品99久久久久久久女警 | 亚洲人永久免费| 久久综合给合| 亚洲一卡久久| 狠狠色噜噜狠狠狠狠色吗综合| 久久久久久久999精品视频| 久久精品国产精品亚洲综合| 国产亚洲欧洲| 欧美成人久久| 欧美午夜精品理论片a级按摩| 久久国产精品久久精品国产| 久久婷婷久久一区二区三区| 亚洲精品综合| 欧美日韩精品伦理作品在线免费观看| 久久九九电影| 亚洲激情成人| 亚洲无限av看| 亚洲激情婷婷| 亚洲视频香蕉人妖| 国产一区视频在线看| 国产伦精品一区二区三区免费迷 | 亚洲第一精品夜夜躁人人爽 | 久久久蜜桃一区二区人| 尤物网精品视频| 欧美一区二区视频97| 亚洲视频在线观看网站| 亚洲日本电影| 亚洲青涩在线| 久久精品道一区二区三区| 亚洲欧美日韩一区二区三区在线| 免费在线一区二区| 久久婷婷成人综合色| 国产日韩欧美a| 亚洲综合色视频| 亚洲一区二区三区乱码aⅴ蜜桃女| 玖玖玖免费嫩草在线影院一区| 99re热这里只有精品免费视频| 国产精品日韩电影| 在线视频你懂得一区二区三区| 欧美日韩一卡| 亚洲国产日韩精品| 91久久线看在观草草青青| 欧美精品激情| 亚洲午夜羞羞片| 亚洲欧美在线另类| 男同欧美伦乱| 亚洲乱码国产乱码精品精可以看 | 欧美精品1区| 欧美午夜精品久久久久久人妖| 国产精品中文在线| 99re成人精品视频| 亚洲国产视频一区二区| 老色批av在线精品| 亚洲日本中文字幕区| 一区二区三区视频在线| 欧美日韩一视频区二区| 一区二区高清视频| 欧美成人精品1314www| 亚洲激情女人| 国产日韩欧美三级| 欧美国产视频在线| 久久爱91午夜羞羞| 一本久道久久综合狠狠爱| 老**午夜毛片一区二区三区| 在线视频你懂得一区| 一色屋精品视频在线看| 国产精品久久激情| 欧美日本三区| 女同一区二区| 久久这里有精品视频| 免费成人高清视频| 美女精品在线| 老司机精品久久|