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

hdu 3374 String Problem 字符串最小、最大表示以及字串重復(fù)次數(shù)(KMP)

題意:
給出一個(gè)字符串,求其所有循環(huán)同構(gòu)串中字典序最大的串以及最小的串。并且計(jì)算這兩個(gè)串在所有循環(huán)同構(gòu)串中出現(xiàn)的次數(shù)

解法:
第一問,用經(jīng)典的求串的最小表示的算法就可以了。
第二問,利用KMP算法前綴數(shù)組的性質(zhì),即最大后綴等于最長前綴的位置。從最小表示(最大表示)的位置開始計(jì)算next函數(shù),將start+len-1位置作合法標(biāo)志,計(jì)算nxt數(shù)組的時(shí)候順便計(jì)算標(biāo)記(與AC自動機(jī)方法相同),然后統(tǒng)計(jì)標(biāo)記個(gè)數(shù)即可~

代碼:(GCC)
 1 # include <string.h>
 2 # include <stdio.h>
 3 # include <stdbool.h>
 4 char str[2050000];
 5 int pre[2050000];
 6 bool end[2050000];
 7 int maxpos(int len)
 8 {
 9     int p1=0,p2=1,l=0,i;
10     while(p1<len&&p2<len&&l<len)
11     {
12         int cmp=str[p1+l]-str[p2+l];
13         if(!cmp)
14              l++;
15         else
16         {
17             if(cmp<0) p1+=l+1;
18             else p2+=l+1;
19             l=0;
20             p2+=(p2==p1);
21         }
22     }
23     return p1<p2?p1:p2;
24 }
25 int minpos(int len)
26 {
27     int p1=0,p2=1,l=0,i;
28     while(p1<len&&p2<len&&l<len)
29     {
30         int cmp=str[p1+l]-str[p2+l];
31         if(!cmp)
32              l++;
33         else
34         {
35             if(cmp>0) p1+=l+1;
36             else p2+=l+1;
37             l=0;
38             p2+=(p2==p1);
39         }
40     }
41     return p1<p2?p1:p2;
42 }
43 int gettimes(int start,int len)
44 {
45     int p,res=0;
46     memset(end,0,sizeof(end));
47     end[start+len-1]=1;
48     pre[start]=start-1;
49     for(p=start+1;p<2*len-1;p++)
50     {
51         pre[p]=pre[p-1];
52         while(pre[p]!=start-1&&str[pre[p]+1]!=str[p]) pre[p]=pre[pre[p]];
53         if(str[pre[p]+1]==str[p]) pre[p]++;
54         if(pre[p]!=start-1&&!end[p]) end[p]=end[pre[p]];
55         res+=end[p];
56     }
57     return res;
58 }
59 int main()
60 {
61     while(gets(str))
62     {
63         int len=strlen(str),i;
64         for(i=len;i<2*len-1;i++) str[i]=str[i-len];
65         str[2*len-1]='\0';
66         int p1=minpos(len);
67         int t1=gettimes(p1,len);
68         printf("%d %d ",p1+1,t1);
69         p1=maxpos(len);
70         t1=gettimes(p1,len);
71         printf("%d %d\n",p1+1,t1);
72     }
73     return 0;
74 }
75 


posted on 2010-11-27 21:06 yzhw 閱讀(615) 評論(0)  編輯 收藏 引用 所屬分類: string algorithm

<2011年3月>
272812345
6789101112
13141516171819
20212223242526
272829303112
3456789

導(dǎo)航

統(tǒng)計(jì)

公告

統(tǒng)計(jì)系統(tǒng)

留言簿(1)

隨筆分類(227)

文章分類(2)

OJ

最新隨筆

搜索

積分與排名

最新評論

閱讀排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美大片免费| 久久久久看片| 欧美在线视频二区| 亚洲男人第一网站| 亚洲欧美日韩天堂一区二区| 亚洲欧美日韩第一区| 欧美一级成年大片在线观看| 久久精品色图| 欧美国产免费| 亚洲日韩中文字幕在线播放| 欧美激情一二区| 日韩一区二区精品葵司在线| 亚洲伊人伊色伊影伊综合网| 久久国产黑丝| 欧美成人蜜桃| 国产精品久久久对白| 国产一区二区丝袜高跟鞋图片| 极品尤物一区二区三区| 亚洲电影在线观看| 一本久道久久久| 久久爱www| 91久久综合| 性欧美1819性猛交| 欧美电影免费观看高清| 欧美日韩中文在线观看| 国产一区二区成人久久免费影院| 亚洲国产欧美另类丝袜| 亚洲欧美国产日韩天堂区| 免费91麻豆精品国产自产在线观看| 亚洲日本理论电影| 久久国产精品毛片| 欧美性猛交99久久久久99按摩| 狠狠爱成人网| 亚洲欧美成人网| 亚洲韩国日本中文字幕| 欧美一区二区在线| 欧美日韩一区二区视频在线观看 | 欧美成人自拍视频| 国产精品捆绑调教| 亚洲裸体俱乐部裸体舞表演av| 欧美一级黄色网| 亚洲国产日韩一区| 久久免费午夜影院| 国产一区999| 香港久久久电影| 日韩亚洲欧美中文三级| 久久夜色精品一区| 狠狠综合久久av一区二区老牛| 亚洲视频在线观看免费| 亚洲欧洲美洲综合色网| 免费在线观看成人av| 怡红院精品视频| 久久午夜精品一区二区| 欧美一级在线视频| 国产美女精品视频| 欧美一级播放| 狂野欧美激情性xxxx| 欧美护士18xxxxhd| 久久久99爱| 伊人久久大香线蕉综合热线| 久久久久久夜精品精品免费| 午夜精品久久久久久久99热浪潮 | 欧美区日韩区| 亚洲盗摄视频| 欧美国产综合| 欧美风情在线| 99亚洲精品| 亚洲精品自在久久| 欧美午夜久久久| 欧美一级久久久| 欧美一区二区高清| 激情婷婷亚洲| 亚洲激情中文1区| 欧美日韩亚洲一区二区三区| 亚洲你懂的在线视频| 午夜久久久久久| …久久精品99久久香蕉国产| 亚洲电影免费观看高清完整版在线观看 | 欧美日韩三级一区二区| 亚洲午夜精品在线| 亚洲欧美一区二区精品久久久| 国产视频在线观看一区| 嫩草成人www欧美| 欧美激情精品久久久久久| 亚洲开发第一视频在线播放| 99精品视频网| 国产一区 二区 三区一级| 亚洲国产精品久久久久秋霞蜜臀 | 在线看日韩av| 亚洲精品国产精品国自产观看| 欧美日韩免费区域视频在线观看| 欧美一区二区三区另类| 久久国产精品黑丝| 制服诱惑一区二区| 久久gogo国模啪啪人体图| 亚洲欧洲精品一区二区三区| 亚洲线精品一区二区三区八戒| 黄色av一区| 在线一区二区三区做爰视频网站| 国产一区二区三区观看| 亚洲九九九在线观看| 国语自产精品视频在线看一大j8 | 欧美成人精品在线视频| 亚洲欧美日韩区| 麻豆视频一区二区| 香港久久久电影| 欧美理论电影网| 麻豆av一区二区三区| 欧美三级午夜理伦三级中文幕 | 免费亚洲一区| 新67194成人永久网站| 老司机午夜精品视频| 亚洲一区在线免费观看| 久久综合一区二区三区| 亚洲资源av| 欧美va亚洲va香蕉在线| 久久精品国产一区二区三区 | 亚洲高清视频的网址| 亚洲无限av看| 一区二区三区国产在线观看| 久久久999精品免费| 久久精品国产v日韩v亚洲 | 亚洲人成在线观看一区二区| 欧美中文在线观看| 欧美在线一二三四区| 欧美色一级片| 亚洲欧洲一区二区三区在线观看 | 欧美在线免费观看| 国产精品二区影院| 亚洲免费成人av电影| 亚洲精品免费在线观看| 久久天天躁夜夜躁狠狠躁2022| 久久九九免费视频| 国产精品一卡二卡| 亚洲女人小视频在线观看| 亚洲综合色丁香婷婷六月图片| 欧美日韩一区二| 一区二区三区日韩精品| 一区二区三区四区国产| 欧美日韩国产一级片| 99国内精品| 亚洲欧美日韩精品久久久| 国产精品电影观看| 午夜久久福利| 免费成人激情视频| 亚洲日本va午夜在线影院| 欧美成熟视频| 亚洲看片一区| 亚洲欧美综合一区| 国产一区二区激情| 麻豆av一区二区三区久久| 欧美国产日韩免费| 日韩一级黄色av| 欧美午夜www高清视频| 亚洲尤物在线视频观看| 久久亚洲精选| 99国产精品视频免费观看一公开| 欧美丝袜一区二区| 小黄鸭精品密入口导航| 免费成人av资源网| 亚洲视频一区| 狠狠88综合久久久久综合网| 欧美激情第三页| 亚洲一区二区精品视频| 久久综合999| 一本久久a久久精品亚洲| 亚洲精品日韩欧美| 国产美女扒开尿口久久久| 久久精品视频在线看| 欧美激情五月| 亚洲免费视频在线观看| 国产色产综合产在线视频| 久久久国产视频91| 亚洲美女视频在线免费观看| 欧美一级精品大片| 亚洲精品久久久久久一区二区 | 国产精品资源在线观看| 久久综合九色99| 中文日韩电影网站| 麻豆乱码国产一区二区三区| 一区二区三区 在线观看视频| 国产一本一道久久香蕉| 欧美涩涩网站| 欧美大片一区二区三区| 亚洲女同性videos| 亚洲黑丝在线| 久久伊人精品天天| 亚洲欧美日韩人成在线播放| 亚洲美女电影在线| 尤物在线精品| 国产农村妇女毛片精品久久莱园子| 欧美+亚洲+精品+三区| 久久成人免费电影| 亚洲午夜激情网页| 亚洲精选中文字幕| 亚洲国产成人高清精品| 久久一二三四| 久久精品久久综合| 羞羞色国产精品| 亚洲在线成人精品|