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

環形串的最優斷點問題

Posted on 2011-04-23 16:09 Mato_No1 閱讀(568) 評論(1)  編輯 收藏 引用 所屬分類: 經典問題的模型字符串匹配
【問題描述】
給出一個環形的字符串S,長度為N,現在要找到一個斷開點,使得從這里斷開后的字符串字典序最小。或者說,對于長度為N的字符串S[0..N-1],找到一個位置i,使得字符串S' = S[i..N-1] + S[0..i-1]的字典序最小。若存在多個這樣的最優斷點,則取最左邊(i最小)的那個。
【Sample Input】
amandamanda
【Sample Output】
10
(從第10位斷開后得到的字符串"aamandamand"的字典序是11個斷開位置中最小的)

【分析】
首先將這個環形串拆開:只需將S[0..N-1]的后面再接上S[0..N-2]即可(如對于樣例,可構造字符串T = "amandamandaamandamand"),則T的任意一個長度為N的子串T[i..i-N+1]就是S從第i位斷開得到的字符串。此時問題就變成了:給出一個長度為(2N-1)的字符串,求出其所有長度為N的子串中字典序最小的

設F[x]為T中所有起始位小于N的長度為x的子串中字典序最小的子串的起始位(若有多個則取最左邊的),如對于T="abaabaaababaabaaa",有F[0]=F[1]=0,F[2]=2,F[3]=F[4]=5……本題的目的就是求出F[N]的值。一開始已知的只有F[0]=0(長度為0的字符串都是空串,字典序都是最小的,取最左邊的第0位)。

可以發現,F數組有很多重要的性質:
性質1 F[0..N]數組是單調遞增的。
證明:用反證法。設存在一個值x(0<=x<N)使得F[x]>F[x+1]則根據定義,有T[F[x+1]..F[x+1]+x]<=T[F[x]..F[x]+x](這里一定不會越界,即F[x]+x的值一定不大于(2N-1),因為x<N,又根據得F[x]<N,故F[x]+x<2N),這樣,必有T[F[x+1]..F[x+1]+x-1]<=T[F[x]..F[x]+x-1]。然而根據F[x]的定義又可以得到T[F[x+1]..F[x+1]+x-1]>T[F[x]..F[x]+x-1](否則F[x]的值就應該等于F[x+1]的值了),矛盾,故在F[0..N]中不可能存在任何F[x]>F[x+1]的情況,也即F[0..N]數組是單調遞增的(以下將F[0..N]數組簡稱為F數組)。
性質2 對于任意值x(0<=x<N),必然滿足F[x+1]=F[x]或F[x+1]>F[x]+x。
證明:因為前面已經證明了F數組是單調遞增的,這里只需證明對于任意x(0<=x<N),不存F[x]<F[x+1]<=F[x]+x的情況即可。
這里同樣用反證法。設存在一個值x(0<=x<N)使得F[x]<F[x+1]<=F[x]+x。則根據定義有T[F[x+1]..F[x+1]+x]<T[F[x]..F[x]+x]且T[F[x]..F[x]+x-1]<=T[F[x+1]..F[x+1]+x-1],這樣必有T[F[x]..F[x]+x-1]=T[F[x+1]..F[x+1]+x-1]且T[F[x+1]+x]<T[F[x]+x]。設D=F[x+1]-F[x],則T[F[x]]=T[F[x]+D],因為D<=x,可得T[F[x]+D]=T[F[x]+2D],即T[F[x]]=T[F[x]+2D]。這樣,T[F[x]..F[x]+x-D-1]=T[F[x]+2D..F[x]+x+D-1];又因為T[F[x]+x-D]=T[F[x]+x],而T[F[x+1]+x](即T[F[x]+x+D]])<T[F[x]+x],這樣,T[F[x]+x+D]<T[F[x]+x-D],也就是,T[F[x]+2D..F[x]+x+D]<T[F[x]..F[x]+x-D]!這樣可以得出,從(F[x]+2D)位開始的任意長度不小于(x-D)的子串,其字典序都小于從F[x]位開始的同樣長度的子串,由于F[x]<F[x+1]<=F[x]+x,D=F[x+1]-F[x],所以有1<=D<=x,這樣,F[x]的值就應該是(F[x]+2D)了,這顯然不可能。所以,一開始假設的這種情況是不可能存在的,即對于任意值x(0<=x<N),必然滿足F[x+1]=F[x]或F[x+1]>F[x]+x。

根據F數組的以上兩個性質可以設計出本題的算法:
設目前已經求出了F[0..x-1]的值,且F[x-1]=i。首先將T[0..i-1]全部刪去(因為F數組是單調遞增的,F[x]的值一定不小于i),然后對T自身作擴展KMP(就是以T為模板串,T為子串的擴展KMP,相當于其預處理部分),一開始先將F[x]置為i,設第j位的匹配長度為next[j],若next[j]=x-1且T[j+x-1]<T[i+x-1],則將F[x]的值改為j,這樣掃描一遍,即求出了F[x]的值。若掃描過程中未出現任何next[j]=x-1,則設所有next[j]值不小于x的最小next[j]值為y,則可以直接得到F[x..y-1]的值均等于F[x-1]。就這樣直到求出F[N]的值為止。

時間復雜度:O(NÖN),可以根據性質2得到。

Feedback

# re: 環形串的最優斷點問題  回復  更多評論   

2012-05-07 21:54 by Mato_No1
@SHUXK
是的,關鍵是本沙茶當時還不會后綴數組,只能用這個
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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| 欧美精品一区二区三区蜜桃| 亚洲国产婷婷香蕉久久久久久| 久久理论片午夜琪琪电影网| 欧美亚洲综合在线| 国产一区二区三区丝袜 | 亚洲激情国产精品| 蜜乳av另类精品一区二区| 久久福利影视| 黄色影院成人| 欧美黄色大片网站| 欧美激情精品久久久久久变态| 亚洲国产视频直播| 亚洲精品免费一二三区| 蜜臀久久99精品久久久画质超高清| 亚洲第一精品夜夜躁人人躁| 蜜桃av噜噜一区| 欧美成人一区二区在线| 一区二区电影免费在线观看| 日韩亚洲欧美成人| 国产精品视频免费| 久久人人爽人人爽爽久久| 久久综合给合久久狠狠狠97色69| 亚洲激情社区| 亚洲特黄一级片| 激情婷婷亚洲| 91久久精品国产91久久性色tv| 欧美久久久久久久久| 亚洲一区二区三区免费在线观看 | 午夜日韩电影| 欧美亚洲尤物久久| 亚洲欧美日韩中文视频| 欧美日韩激情小视频| 亚洲日本理论电影| 亚洲小视频在线| 国产精品爱久久久久久久| 在线综合亚洲| 性欧美暴力猛交69hd| 国产视频一区欧美| 欧美国产日韩在线| 午夜一区二区三视频在线观看| 蜜臀久久久99精品久久久久久| 在线观看成人一级片| 欧美日韩在线一区二区| 亚洲精品综合久久中文字幕| 午夜欧美精品| 99www免费人成精品| 国内精品久久久久影院 日本资源| 欧美在线影院| 欧美中文字幕久久| 99精品99| 亚洲黄一区二区| 国产一区二区黄| 欧美三级视频在线观看| 久久夜色精品国产欧美乱| 一本一本a久久| 亚洲乱码国产乱码精品精天堂| 另类图片综合电影| 欧美一区1区三区3区公司| 亚洲欧洲午夜| 一区国产精品| 国产麻豆一精品一av一免费| 久久综合久久美利坚合众国| 在线中文字幕日韩| 亚洲精品孕妇| 欧美xx视频| 久久久久久久波多野高潮日日| 久久综合中文字幕| 亚洲最黄网站| 99视频超级精品| 亚洲黄色一区| 亚洲第一毛片| 亚洲国产第一页| 亚洲精品免费一二三区| 亚洲精品在线视频观看| 日韩西西人体444www| 亚洲免费观看在线观看| 日韩视频精品在线| 日韩一区二区免费看| 亚洲毛片在线看| 99热在线精品观看| 亚洲夜晚福利在线观看| 老司机精品视频网站| 久久久精品性| 亚洲欧美日韩一区| 亚洲一区二区黄色| 亚洲欧美影音先锋| 鲁大师影院一区二区三区| 久久亚洲影院| 欧美巨乳在线观看| 欧美日韩成人网| 国产伦理一区| 亚洲精品美女91| 午夜精品久久久久久| 老司机精品久久| 免费不卡亚洲欧美| 亚洲欧洲另类| 久久成人免费电影| 欧美三日本三级三级在线播放| 国产女人精品视频| 亚洲精品一区二| 久久久久久久久久久成人| 久久精品免费看| 欧美激情中文不卡| 亚洲美女黄网| 亚洲免费大片| 欧美一区二区三区在线| 亚洲福利国产| 美女免费视频一区| 亚洲欧洲日本一区二区三区| 日韩亚洲成人av在线| 欧美777四色影视在线| 欧美日韩国产免费观看| 亚洲电影免费观看高清完整版在线| 亚洲在线一区二区| 一区二区激情小说| 国产精品一区二区在线| 好看的av在线不卡观看| 欧美亚洲视频| 亚洲一级网站| 国产精品人人做人人爽人人添| 日韩午夜精品| 在线视频日韩| 国产精品ⅴa在线观看h| 久久久噜噜噜久噜久久| 久久亚洲一区| 91久久精品日日躁夜夜躁欧美| 亚洲二区精品| 国产精品视频一区二区三区 | 亚洲尤物在线| 欧美在线观看www| 亚洲精品一区二区三| 亚洲综合不卡| 精东粉嫩av免费一区二区三区| 亚洲高清精品中出| 国产精品美女久久久久久2018| 欧美一区激情视频在线观看| 久久亚洲综合色| 亚洲欧美精品在线| 欧美大片一区| 老巨人导航500精品| 欧美日韩在线免费视频| 狂野欧美性猛交xxxx巴西| 欧美片第1页综合| 久久蜜桃香蕉精品一区二区三区| 欧美激情一区二区久久久| 久久精品国产96久久久香蕉| 欧美日韩在线播放一区二区| 欧美夫妇交换俱乐部在线观看| 国产欧美日韩在线观看| 亚洲网站在线看| 欧美一区二区免费视频| 99精品视频免费| 亚洲乱码视频| 欧美激情国产高清| 亚洲激情在线观看| 99re热精品| 国产精品国产三级国产普通话99 | 欧美特黄一级大片| 亚洲在线不卡| 久久久精品国产一区二区三区| 国内精品国产成人| 久久亚洲一区二区| 亚洲精品乱码久久久久久| 亚洲欧美国产毛片在线| 国内久久婷婷综合| 欧美不卡一卡二卡免费版| 一区二区三区av| 久久精品亚洲精品| 99re这里只有精品6| 国产精品一级| 欧美精品激情| 久久麻豆一区二区| 亚洲一区二区免费视频| 久久亚洲精选| 香蕉视频成人在线观看| 亚洲国产黄色片| 国产精品伊人日日| 欧美日韩1区2区| 欧美不卡三区| 久久精品国亚洲| 亚洲一区日韩在线| 99视频+国产日韩欧美| 亚洲激情影院| 欧美激情亚洲自拍| 欧美大片第1页| 久久久亚洲精品一区二区三区| 亚洲视频在线播放| 日韩视频在线免费| 亚洲日本中文字幕| 亚洲美女精品久久| 亚洲靠逼com|