字符串的最小表示法

字符串的循環(huán)同構(gòu):
設(shè)S=bcad,且S’是S的循環(huán)同構(gòu)的串。S’可以是bcad或者cadb,adbc,dbca。而且最小表示的S’是adbc。
對(duì)于字符串循環(huán)同構(gòu)的最小表示法,其問(wèn)題實(shí)質(zhì)是求S串的一個(gè)位置,從這個(gè)位置開(kāi)始循環(huán)輸出S,得到的S’字典序最小。
顯然兩個(gè)字符串循環(huán)同構(gòu)的充分必要條件是這兩個(gè)字符串的最小表示法相等。
字符串循環(huán)同構(gòu)可以看這篇論文:點(diǎn)這里~

下面給出求最小表示法的模板:
函數(shù)返回一個(gè)位置,從這個(gè)位置開(kāi)始循環(huán)輸出S,得到的S’字典序最小。

int getMin(char *str)
{
    int i=0,j=1,k=0;
    int slen=strlen(str);
    while(i<slen&&j<slen&&k<slen)
    {
        int tmp=str[(i+k)%slen]-str[(j+k)%slen];
        if(tmp==0) k++;
        else
        {
            if(tmp>0) i=i+k+1;
            else j=j+k+1;
            if(j==i) j++;
            k=0;
        }
    }
    return min(i,j);
}

同理,求最大表示法只是把大于等于號(hào)的內(nèi)容改一下

int getMax(char *str)
{
    int i=0,j=1,k=0;
    int slen=strlen(str);
    while(i<slen&&j<slen&&k<slen)
    {
        int tmp=str[(i+k)%slen]-str[(j+k)%slen];
        if(tmp==0) k++;
        else
        {
            if(tmp>0) j=j+k+1;
            else i=i+k+1;
            if(i==j) j++;
            k=0;
        }
    }
    return min(i,j);
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 第5章 引用類(lèi)型(返回首頁(yè)) 本章內(nèi)容 使用對(duì)象 創(chuàng)建并操作數(shù)組 理解基本的JavaScript類(lèi)型 使用基本類(lèi)型...
    大學(xué)一百閱讀 3,667評(píng)論 0 4
  • 不錯(cuò)的博客求next數(shù)組: 注意:求next數(shù)組得到的最長(zhǎng)公共前綴后綴是可以重疊的:比如:ababa,next[5...
    Gitfan閱讀 950評(píng)論 0 0
  • 字符的 Unicode 表示法 codePointAt() String.fromCodePoint() 字符串的...
    卞卞村長(zhǎng)L閱讀 831評(píng)論 0 0
  • 也許你會(huì)看到笑魘如花的我,可永遠(yuǎn)回會(huì)發(fā)現(xiàn)我眼眸的憂(yōu)傷,轉(zhuǎn)身落淚的心痛無(wú)人會(huì)懂。
    筱曉夢(mèng)閱讀 181評(píng)論 0 0
  • 本來(lái)想這個(gè)周五早點(diǎn)兒入睡,但老公說(shuō)“今天雙十一開(kāi)始預(yù)購(gòu),你想買(mǎi)點(diǎn)兒什么嗎?”我一但點(diǎn)開(kāi)頁(yè)面,有點(diǎn)兒控制不住,就刷天...
    LilyZheng閱讀 465評(píng)論 1 2

友情鏈接更多精彩內(nèi)容