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

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>
            美女网站久久| 久久久精品网| 国产精品午夜视频| 老鸭窝91久久精品色噜噜导演| 亚洲欧洲精品一区二区三区 | 亚洲激情六月丁香| 久热精品视频在线免费观看| 欧美一区二区观看视频| 亚洲一二三级电影| 亚洲美女性视频| 亚洲精品视频一区| 一本一道久久综合狠狠老精东影业 | 久久综合给合久久狠狠狠97色69| 欧美福利影院| 日韩一级大片在线| 亚洲女人av| 中文av一区二区| 午夜精品久久久久| 欧美成人中文| 日韩视频免费看| 性亚洲最疯狂xxxx高清| 欧美大片一区| 国产欧美日本一区二区三区| 激情丁香综合| 亚洲人成网站影音先锋播放| 亚洲欧美中文另类| 欧美激情精品久久久久久免费印度 | 亚洲视频一二区| 欧美亚洲视频| 亚洲国产日韩综合一区| 亚洲欧美日韩视频一区| 欧美成人小视频| 欧美新色视频| 樱桃成人精品视频在线播放| 亚洲免费电影在线| 午夜在线视频观看日韩17c| 久久免费视频在线| 亚洲欧美国产制服动漫| 欧美喷水视频| 精久久久久久久久久久| 影音先锋日韩有码| 亚洲一区影音先锋| 亚洲国产精品一区二区第四页av| 亚洲国产毛片完整版 | 欧美11—12娇小xxxx| 欧美伊人久久| 一区二区电影免费观看| 久久免费精品日本久久中文字幕| 老司机精品久久| 欧美成人综合| 午夜一区二区三视频在线观看| 老鸭窝91久久精品色噜噜导演| 国产自产在线视频一区| 久久久高清一区二区三区| 欧美中文字幕久久| 亚洲伦理一区| 欧美亚洲一区| 亚洲乱码精品一二三四区日韩在线| 欧美福利一区| 国产精品久久久久久久久久久久久 | 国产亚洲毛片在线| 免费人成精品欧美精品| 欧美 日韩 国产在线| 香蕉久久夜色精品| 麻豆成人在线观看| 欧美在线一二三四区| 蜜臀久久久99精品久久久久久| 欧美国产第一页| 国产精品啊啊啊| 91久久精品美女| 激情五月婷婷综合| 日韩一级片网址| 精品88久久久久88久久久| 亚洲福利视频三区| 亚洲中字黄色| 亚洲欧美成人一区二区在线电影 | 久久九九全国免费精品观看| 亚洲欧洲日本专区| 久久国产精品久久久久久久久久| 亚洲日本久久| 欧美韩日高清| 亚洲免费电影在线观看| 亚洲日本中文字幕| 欧美+日本+国产+在线a∨观看| 久久狠狠婷婷| 亚洲国产精品一区二区尤物区| 一本色道久久综合一区| 99视频精品免费观看| 蜜臀91精品一区二区三区| 欧美顶级艳妇交换群宴| 亚洲欧洲一区二区天堂久久| 午夜精品久久久久久久| 美女诱惑一区| 国产精品亚洲激情| 久久久国产午夜精品| 欧美日韩国产123区| 在线视频欧美一区| 久久先锋影音| 一区二区三区精密机械公司| 欧美性大战久久久久久久| 性欧美videos另类喷潮| 看片网站欧美日韩| av72成人在线| 国产精品一区二区三区久久| 久久精品国产综合精品| 夜夜嗨av一区二区三区四季av| 久久精品免费播放| 欧美日韩妖精视频| 翔田千里一区二区| 日韩亚洲视频| 欧美sm重口味系列视频在线观看| 一区二区高清在线| 91久久精品日日躁夜夜躁欧美| 欧美片在线观看| 久久久久久91香蕉国产| 欧美一区二区三区在线| 亚洲精品极品| 亚洲人成艺术| 亚洲日本免费| 一本久道综合久久精品| 久久久国际精品| 亚洲免费在线播放| 亚洲欧美一区二区激情| 亚洲欧美综合v| 久久漫画官网| 欧美不卡激情三级在线观看| 亚洲桃色在线一区| 亚洲高清在线观看| 亚洲国产小视频| 欧美高清视频| 欧美激情在线| 亚洲午夜91| 免费观看一区| 国产精品高潮呻吟久久av无限| 欧美日韩一区三区| 国产乱码精品一区二区三区av| 欧美私人网站| 一区二区在线看| 亚洲午夜在线视频| 久久精品在线观看| 亚洲电影在线播放| 亚洲小视频在线| 欧美成人激情视频免费观看| 欧美成人蜜桃| 国产精品男人爽免费视频1| 在线观看亚洲a| 午夜视黄欧洲亚洲| 亚洲福利视频三区| 国产日韩欧美黄色| 欧美日韩成人激情| 国产精品乱人伦一区二区| 狠狠色噜噜狠狠色综合久 | 欧美中文日韩| 日韩视频免费大全中文字幕| 久久久久久久性| 国产精品福利网| 在线观看日产精品| 久久免费黄色| 亚洲欧美文学| 国产欧美精品| 小黄鸭视频精品导航| 一区二区三区偷拍| 欧美精品综合| 日韩小视频在线观看专区| 亚洲国产精品久久91精品| 欧美一级网站| 亚洲日本黄色| 亚洲亚洲精品在线观看| 国产噜噜噜噜噜久久久久久久久| 亚洲一级黄色片| 亚洲免费av观看| 国产视频观看一区| 免费av成人在线| 亚洲人成高清| 一区二区三区视频在线观看| 国产网站欧美日韩免费精品在线观看| 欧美亚洲一级| 免费一区视频| 久久久久久高潮国产精品视| 久久久久99精品国产片| 亚洲精品视频在线观看免费| 亚洲美女av网站| 亚洲福利国产精品| 亚洲欧美国产高清va在线播| 在线视频成人| 亚洲欧美激情一区| 日韩亚洲欧美一区| 久久一二三国产| 香蕉久久精品日日躁夜夜躁| 蜜桃av久久久亚洲精品| 欧美理论电影在线观看| 午夜伦理片一区| 美女视频网站黄色亚洲| 久久精品国产第一区二区三区最新章节 | 国产色综合天天综合网| 亚洲美女91| 一区二区三区黄色| 免费观看欧美在线视频的网站| 午夜视频在线观看一区二区三区| 欧美福利电影网|