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

            Why so serious? --[NKU]schindlerlee

            2010年1月30日星期六.sgu142 枚舉....

            2010年1月30日星期六.sgu142
            sgu142:枚舉

            ∵ (1)最長的長度是500000
            ∵ (2)長度為19的串總共可能有524288,
            ∴ 長度<=19的串中一定有原串沒有出現過的
            ∴ 枚舉每個長度的串然后找到一個沒有出現的即可

             1 
             2 #define bin(x) (1 << (x))
             3 #define L(x) ((x) << 1)
             4 const int N = bin(20);
             5 int hash[N], n;
             6 int str[N], two[32];//http://www.shnenglu.com/schindlerlee/
             7 bool find(int len)
             8 {
             9   int i, j, cur = 0, mask = two[len] - 1;
            10   memset(hash, 0sizeof(int* two[len]);
            11 
            12   for (i = 0; i < len - 1; i++) { cur = L(cur) + str[i]; }
            13   for (i = len - 1; i < n; i++) {
            14       cur = (L(cur) + str[i]) & mask;
            15       hash[cur] = 1;
            16   }
            17 
            18   for (i = 0; i <= mask; i++) {
            19       if (hash[i] == 0) {
            20           printf("%d\n", len);
            21           for (j = len - 1; j >= 0; j--) {
            22               if (two[j] & i) {
            23                   printf("b");
            24               } else {
            25                   printf("a");
            26               }
            27           }
            28           putchar(10);
            29           return true;
            30       }
            31   }
            32   return false;
            33 }
            34 
            35 int main()
            36 {
            37   int i;
            38   scanf("%d\n"&n);
            39   for (i = 0; i <= 22; i++) { two[i] = bin(i); }
            40   for (i = 0; i < n; i++) { str[i] = (getchar() == 'b'); }
            41 
            42   for (i = 1;i < 20; i++) {
            43       if (find(i)) {
            44           break;
            45       }
            46   }
            47   return 0;
            48 }
            49 
            50 

            posted on 2010-01-30 17:57 schindlerlee 閱讀(1182) 評論(0)  編輯 收藏 引用 所屬分類: 解題報告

            久久久久久久综合狠狠综合| 久久精品国产欧美日韩| 亚洲欧美成人综合久久久 | 久久久国产99久久国产一| 一本久久综合亚洲鲁鲁五月天| 久久精品国产亚洲AV久| 亚洲AV无码久久精品色欲| 国产福利电影一区二区三区久久老子无码午夜伦不 | 日韩人妻无码一区二区三区久久| 2021久久国自产拍精品| 亚洲午夜无码久久久久小说| 久久精品aⅴ无码中文字字幕重口 久久精品a亚洲国产v高清不卡 | 久久精品国产WWW456C0M| 亚洲AV乱码久久精品蜜桃| 精品久久久无码中文字幕天天| 久久夜色精品国产噜噜噜亚洲AV| 日韩电影久久久被窝网| 久久99国产精品一区二区| 亚洲熟妇无码另类久久久| 久久久黄片| 国产—久久香蕉国产线看观看| 久久综合给合久久狠狠狠97色69| 久久久久久久久66精品片| 久久久无码精品午夜| 99久久亚洲综合精品网站| 久久精品国产亚洲AV无码偷窥 | 99久久国产亚洲高清观看2024| 久久无码人妻一区二区三区午夜| 国产精品久久久久久久人人看 | 无码人妻久久一区二区三区 | 精品国产青草久久久久福利| 久久这里只有精品久久| 中文字幕成人精品久久不卡| 久久久青草青青亚洲国产免观| 高清免费久久午夜精品| 国产成人精品白浆久久69| 国产成人久久精品激情| 久久国产精品-国产精品| 91精品无码久久久久久五月天| 精品国产一区二区三区久久| 国产精品久久久久无码av|