• <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 Za, A Za, Fighting...

            堅信:勤能補拙

            PKU 1020 Anniversary Cake

            問題:
            http://acm.pku.edu.cn/JudgeOnline/problem?id=1020

            思路:
            原本以為是挺簡單的題,結果卻始終不知道怎么搜索,艾...備受打擊
            雖然目前對于回溯部分的代碼理解起來已經沒有困難,對于每次搜索都從占用最少的列開始,還是不明白為什么...

            參考:
            http://www.shnenglu.com/RyanWang/archive/2008/10/26/65051.aspx

            代碼:
             1 #define MAX_LEN 42
             2 #define MAX_SIZE 11
             3 int size, n;
             4 int used[MAX_LEN], pieces[MAX_SIZE];
             5 int flag;
             6 
             7 void
             8 dfs(int depth)
             9 {
            10     int i, j, col, min_used=MAX_LEN;
            11     if(depth == n) {
            12         flag = 1;
            13         return;
            14     }
            15     for(i=1; i<=size; i++)
            16         if(used[i] < min_used) {
            17             min_used = used[i];
            18             col = i;
            19         }
            20     for(i=10; i>=1; i--) {
            21         if(pieces[i]>0 && used[col]+i<=size && col+i-1<=size) {
            22             for(j=col; j<=col+i-1; j++)
            23                 if(used[j]>min_used)
            24                     break;
            25             if(j>col+i-1) {
            26                 --pieces[i];
            27                 for(j=col; j<=col+i-1; j++)
            28                     used[j] += i;
            29                 dfs(depth+1);
            30                 for(j=col; j<=col+i-1; j++)
            31                     used[j] -= i;
            32                 ++pieces[i];
            33             }
            34         }
            35     }
            36 }
            37 
            38 int
            39 main(int argc, char **argv)
            40 {
            41     int i, tmp, tests, sum;
            42     scanf("%d"&tests);
            43     while(tests--) {
            44         memset(used, 0sizeof(used));
            45         memset(pieces, 0sizeof(pieces));
            46         flag = 0;
            47         scanf("%d %d"&size, &n);
            48         sum = 0;
            49         for(i=0; i<n; i++) {
            50             scanf("%d"&tmp);
            51             ++pieces[tmp];
            52             sum += (tmp*tmp);
            53         }
            54         if(sum == size*size)
            55             dfs(0);
            56         printf("%s\n", flag==1 ? "KHOOOOB!" : "HUTUTU!");
            57     }
            58 }

            posted on 2010-08-10 19:42 simplyzhao 閱讀(235) 評論(0)  編輯 收藏 引用 所屬分類: B_搜索

            導航

            <2010年8月>
            25262728293031
            1234567
            891011121314
            15161718192021
            22232425262728
            2930311234

            統計

            常用鏈接

            留言簿(1)

            隨筆分類

            隨筆檔案

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            秋霞久久国产精品电影院| 蜜臀av性久久久久蜜臀aⅴ| 久久久久久久综合日本亚洲| 99精品国产在热久久| 国产 亚洲 欧美 另类 久久| 久久久这里只有精品加勒比| 久久久久免费精品国产| 伊人久久一区二区三区无码| 久久国产亚洲高清观看| 久久婷婷人人澡人人| 潮喷大喷水系列无码久久精品 | 日韩精品久久无码中文字幕| 93精91精品国产综合久久香蕉| 免费精品久久天干天干| 国产福利电影一区二区三区久久久久成人精品综合 | 97久久精品无码一区二区| 久久久久久亚洲精品不卡 | 狠狠色丁香久久综合婷婷| 一级a性色生活片久久无少妇一级婬片免费放 | 久久人爽人人爽人人片AV| 久久精品国产一区二区三区| 久久99国产综合精品女同| 亚洲国产成人精品91久久久 | 一本久久a久久精品综合香蕉| 久久福利青草精品资源站免费| 国产美女亚洲精品久久久综合| 久久久91人妻无码精品蜜桃HD| 国产精品久久久久久久久| 无码人妻少妇久久中文字幕蜜桃| 一级A毛片免费观看久久精品| 久久久久久久久久久免费精品| 久久香蕉国产线看观看乱码| 久久综合狠狠综合久久综合88| 无遮挡粉嫩小泬久久久久久久| 热99RE久久精品这里都是精品免费 | 人妻无码αv中文字幕久久琪琪布 人妻无码精品久久亚瑟影视 | 精品久久人妻av中文字幕| 亚洲va中文字幕无码久久| 久久国产色av免费看| 日韩精品久久久久久免费| 性高湖久久久久久久久|