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

【問題描述】
給出一個(gè)環(huán)形的字符串S,長度為N,現(xiàn)在要找到一個(gè)斷開點(diǎn),使得從這里斷開后的字符串字典序最小。或者說,對(duì)于長度為N的字符串S[0..N-1],找到一個(gè)位置i,使得字符串S' = S[i..N-1] + S[0..i-1]的字典序最小。若存在多個(gè)這樣的最優(yōu)斷點(diǎn),則取最左邊(i最小)的那個(gè)。
【Sample Input】
amandamanda
【Sample Output】
10
(從第10位斷開后得到的字符串"aamandamand"的字典序是11個(gè)斷開位置中最小的)

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

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

可以發(fā)現(xiàn),F(xiàn)數(shù)組有很多重要的性質(zhì):
性質(zhì)1 F[0..N]數(shù)組是單調(diào)遞增的。
證明:用反證法。設(shè)存在一個(gè)值x(0<=x<N)使得F[x]>F[x+1]則根據(jù)定義,有T[F[x+1]..F[x+1]+x]<=T[F[x]..F[x]+x](這里一定不會(huì)越界,即F[x]+x的值一定不大于(2N-1),因?yàn)閤<N,又根據(jù)得F[x]<N,故F[x]+x<2N),這樣,必有T[F[x+1]..F[x+1]+x-1]<=T[F[x]..F[x]+x-1]。然而根據(jù)F[x]的定義又可以得到T[F[x+1]..F[x+1]+x-1]>T[F[x]..F[x]+x-1](否則F[x]的值就應(yīng)該等于F[x+1]的值了),矛盾,故在F[0..N]中不可能存在任何F[x]>F[x+1]的情況,也即F[0..N]數(shù)組是單調(diào)遞增的(以下將F[0..N]數(shù)組簡稱為F數(shù)組)。
性質(zhì)2 對(duì)于任意值x(0<=x<N),必然滿足F[x+1]=F[x]或F[x+1]>F[x]+x。
證明:因?yàn)榍懊嬉呀?jīng)證明了F數(shù)組是單調(diào)遞增的,這里只需證明對(duì)于任意x(0<=x<N),不存F[x]<F[x+1]<=F[x]+x的情況即可。
這里同樣用反證法。設(shè)存在一個(gè)值x(0<=x<N)使得F[x]<F[x+1]<=F[x]+x。則根據(jù)定義有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]。設(shè)D=F[x+1]-F[x],則T[F[x]]=T[F[x]+D],因?yàn)镈<=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];又因?yàn)門[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(xiàn)[x]的值就應(yīng)該是(F[x]+2D)了,這顯然不可能。所以,一開始假設(shè)的這種情況是不可能存在的,即對(duì)于任意值x(0<=x<N),必然滿足F[x+1]=F[x]或F[x+1]>F[x]+x。

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

時(shí)間復(fù)雜度:O(NÖN),可以根據(jù)性質(zhì)2得到。

Feedback

# re: 環(huán)形串的最優(yōu)斷點(diǎn)問題  回復(fù)  更多評(píng)論   

2012-05-07 21:54 by Mato_No1
@SHUXK
是的,關(guān)鍵是本沙茶當(dāng)時(shí)還不會(huì)后綴數(shù)組,只能用這個(gè)
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            蜜臀久久久99精品久久久久久| 亚洲一卡久久| 欧美高清在线观看| 久久国产婷婷国产香蕉| 亚洲性色视频| 日韩视频在线观看国产| 亚洲第一狼人社区| 亚洲青涩在线| 亚洲一区二区三区在线观看视频| 午夜国产精品影院在线观看| 亚洲综合电影| 久久久五月天| 91久久在线观看| 欧美电影在线| 亚洲国内在线| 亚洲一级免费视频| 久久国产66| 蜜桃视频一区| 久久aⅴ国产紧身牛仔裤| 亚洲国产精品传媒在线观看| 亚洲精品在线免费| 中文欧美日韩| 欧美精品999| 国产免费成人av| **欧美日韩vr在线| 99精品欧美一区| 久久久久久久久综合| 亚洲激情视频网| 午夜精品久久久久久久白皮肤| 久久久久久精| 国产精品网站在线| 亚洲人成艺术| 久久亚洲春色中文字幕| 99在线精品视频| 久久久精品国产免费观看同学| 亚洲国产三级网| 亚洲欧美视频一区| 欧美日韩视频免费播放| 国产一区二区三区久久精品| 一本色道久久加勒比88综合 | 国产精品乱子久久久久| 狠狠综合久久| 日韩亚洲欧美高清| 美女999久久久精品视频| 在线亚洲激情| 午夜精品一区二区三区在线播放| 午夜宅男欧美| 欧美区日韩区| 亚洲大胆视频| 西瓜成人精品人成网站| 亚洲久久一区| 欧美激情第10页| 在线免费观看视频一区| 久久久久一区二区三区四区| 日韩视频一区二区三区| 久久久国产午夜精品| 国产精品一区二区欧美| 午夜视频在线观看一区二区三区| 亚洲第一中文字幕| 久久精品一区四区| 亚洲一区高清| 国产精品国色综合久久| 日韩亚洲精品视频| 91久久精品美女| 蜜臀av一级做a爰片久久| 影音先锋中文字幕一区二区| 久久九九久精品国产免费直播| 99精品欧美一区| 欧美精品电影| 亚洲综合色丁香婷婷六月图片| 在线视频一区观看| 国产视频一区免费看| 久久夜色精品国产亚洲aⅴ| 亚洲巨乳在线| 国产欧美日韩亚洲一区二区三区| 午夜精品久久久久久久蜜桃app | 亚洲一二三区精品| 一二三区精品| 国产欧美日韩在线| 蜜桃久久精品一区二区| 男女视频一区二区| 亚洲精品一区二区三区樱花| 欧美激情第10页| 欧美日韩一区二区三区免费| 亚洲一区二区免费在线| 亚洲视频在线观看三级| 黄色日韩在线| 亚洲欧洲在线视频| 国产精品成人免费| 久久国产乱子精品免费女| 欧美中文字幕在线观看| 在线成人av.com| 亚洲国产精品一区在线观看不卡| 欧美欧美天天天天操| 亚洲一区二区在线免费观看| 性欧美1819性猛交| 永久域名在线精品| 亚洲国产精品久久91精品| 国产精品色午夜在线观看| 久久免费视频在线观看| 欧美激情欧美激情在线五月| 亚洲电影第三页| 一本大道久久a久久综合婷婷| 国产伦精品一区二区三区照片91 | 国产精品99久久久久久人| 在线亚洲欧美视频| 国产亚洲精久久久久久| 蜜乳av另类精品一区二区| 国产精品久久久久久超碰 | 免费日韩视频| 久久久成人网| 国产精品久久久久久影院8一贰佰| 狠狠色伊人亚洲综合网站色| 亚洲精品黄色| 在线欧美亚洲| 久久成人国产| 性欧美1819性猛交| 欧美日韩一区视频| 亚洲国产另类久久久精品极度| 国产精品日韩欧美一区二区三区 | 欧美精品自拍偷拍动漫精品| 亚洲欧美欧美一区二区三区| 欧美在线视频一区二区三区| 亚洲天堂视频在线观看| 久久免费偷拍视频| 欧美中文字幕精品| 国产精品久久久久久久久久久久久| 欧美国产激情二区三区| 黄色成人在线免费| 亚洲精品资源| 这里只有精品丝袜| 欧美精品在线一区二区| 亚洲国产精品va在线看黑人| 激情一区二区| 久久久久久999| 久久伊人免费视频| 激情久久五月天| 午夜国产欧美理论在线播放| 亚洲欧美日韩一区二区| 欧美成人三级在线| 欧美大片免费观看| 亚洲经典在线看| 久久蜜桃香蕉精品一区二区三区| 久久久噜噜噜久久中文字免| 国产一区二区三区四区| 久久不射电影网| 久热re这里精品视频在线6| 在线观看一区二区精品视频| 久久免费视频一区| 亚洲高清视频在线| 亚洲日本免费| 欧美色道久久88综合亚洲精品| 亚洲视频欧美视频| 韩日在线一区| 欧美成年人视频网站| 久久综合一区二区| 亚洲电影免费在线观看| 久久亚洲国产精品一区二区| 美腿丝袜亚洲色图| 亚洲精选国产| 国产精品久久久久9999高清| 久久精品99国产精品酒店日本| 欧美激情成人在线视频| 亚洲视频成人| 国语自产精品视频在线看| 久久久一二三| 亚洲国产精品成人久久综合一区| 亚洲一区二区三区视频| 国产亚洲一区二区三区在线播放| 久久理论片午夜琪琪电影网| 蜜臀a∨国产成人精品| 一本大道久久精品懂色aⅴ| 国产精品毛片大码女人| 久久精品国产亚洲aⅴ| 亚洲精品国产精品国产自| 久久av一区二区三区漫画| 最新国产拍偷乱拍精品| 国产精品久久久久久模特| 狼狼综合久久久久综合网| 亚洲视频久久| 在线观看日韩精品| 国产精品美腿一区在线看 | 亚洲影音一区| 一区二区三区在线视频播放| 欧美三级视频在线播放| 久久精品国产免费看久久精品| 欧美成人精品影院| 午夜精品久久久久久久蜜桃app| 在线观看成人av| 欧美日韩一区二区三区在线观看免 | 先锋a资源在线看亚洲| 亚洲丰满少妇videoshd| 欧美精品aa| 久久综合激情| 欧美综合77777色婷婷| 一区二区电影免费在线观看| 免费一区视频| 久久精视频免费在线久久完整在线看| 一区二区三区欧美在线| 亚洲国产毛片完整版|