• <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>

            a tutorial on computer science

              C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
              21 隨筆 :: 0 文章 :: 17 評論 :: 0 Trackbacks
                給出一個長度為N的字符串,求出它的最小表示。
                算法是線性的,具體做法是設置兩個指針fst,sec。fst代表當前找到的最小的字符串表示,sec表示下一個要匹配的初始位置。暴力的做法就是每次sec向后面移動一位o(N^2)的算法。線性的做法是根據前面的結果移動fst和sec。當我們比較fst和sec形成的字符串的時候,有三種情況。第一種是比較到了第fst+len-1位和sec+len-1位置,相等。那么我們發現,fst和sec相等,不用多說,fst要移動到sec位置,sec移動到sec+1位置。這個比較明顯。然后是比較到第i位置的時候,str[fst+i] > str[ (sec + i )%len],我們可以看到sec現在比fst小了,那么fst = sec, sec++。這也比較明顯。然后是str[fst+i] < str[ (sec + i )%len],這樣,我們可以看到,以fst+k(k<i)的字符串和fst比,都比fst大,然后sec+i也比fst+i大,那么可知,sec到sec+i的那些玩意就不用再和fst比了,他們肯定比fst小。sec = sec+i+1。好了,其實是比較明顯的一個算法,推一下就差不多了。第一次寫錯在了當相等的時候直接返回了,汗。寫的還算干凈。#include <cstdio>
            #include <cstring>

            const int maxn = 1001000;

            char str[maxn];

            int getans(int tlen)
            {
              int len = tlen;
              int fst = 0,sec = 1,i;

              while(sec < len)
              {
                for(i=0;i<len;i++)
                {
                  if(str[fst+i] != str[(sec+i)%len])
                    break;
                }
                if(i == len)
                {
                      fst = sec;
                      sec = sec + 1;
                }
                else if(str[fst+i] < str[(sec+i)%len])
                {
                   sec = sec + i + 1;
                }
                else if(str[fst+i] > str[(sec+i)%len])
                 {
                   fst = sec;
                   sec = sec + 1;
                 }
              }
              return fst;
            }

            int main()
            {
              int tcase,tlen;
              scanf("%d",&tcase);
              while(tcase--)
              {
                scanf("%d%s",&tlen,str);
                int ans = getans(tlen);
                printf("%d\n",ans);
              }
              return 0;
            }
            posted on 2012-08-02 15:36 bigrabbit 閱讀(986) 評論(0)  編輯 收藏 引用
            久久99精品久久久久久9蜜桃| 亚洲国产精品无码久久九九| 午夜不卡久久精品无码免费| 东方aⅴ免费观看久久av| 久久婷婷五月综合色奶水99啪| 国产精品久久久久久福利69堂| 伊人久久精品线影院| 一本久久综合亚洲鲁鲁五月天亚洲欧美一区二区 | 久久国产免费直播| 99久久精品毛片免费播放| 国产免费福利体检区久久| 狠狠色丁香久久婷婷综合| 国产成人久久久精品二区三区| 精品伊人久久久| 亚洲国产成人久久精品动漫| 中文字幕无码精品亚洲资源网久久 | 无码人妻精品一区二区三区久久| 久久亚洲欧美日本精品| 国产精品美女久久福利网站| 丁香五月综合久久激情| 伊人久久精品无码二区麻豆| 久久综合成人网| 91久久精品国产免费直播| 色欲久久久天天天综合网精品 | 亚洲精品午夜国产VA久久成人| 久久e热在这里只有国产中文精品99| 奇米影视7777久久精品| 精品国产青草久久久久福利| 久久国产精品免费一区二区三区| 精品久久久久久久无码 | 国产精品成人精品久久久| 国产精品久久久久久久久免费| 久久国产欧美日韩精品| 久久妇女高潮几次MBA| 久久经典免费视频| 日日狠狠久久偷偷色综合96蜜桃 | 久久se这里只有精品| 国产福利电影一区二区三区久久久久成人精品综合 | 99久久香蕉国产线看观香| 看全色黄大色大片免费久久久| 久久中文字幕一区二区|