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

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

            思路:
            深度搜索
            純粹按照題意進行搜索,1532MS...額...就快TLE了呵呵
            據discussion說,倒過來搜索時間會相當快

            代碼:
             1 #define MAX_LEN 10
             2 char table[MAX_LEN][MAX_LEN];
             3 int flag;
             4 
             5 int
             6 is_available(int x, int y, char ch)
             7 {            
             8     int j, k, small_x, small_y;
             9     for(j=0; j<9; j++/* row */
            10         if(table[x][j]==ch)
            11             return 0;
            12     for(k=0; k<9; k++/* column */
            13         if(table[k][y]==ch)
            14             return 0;
            15     small_x = x/3;
            16     small_y = y/3;
            17     for(j=small_x*3; j<(small_x+1)*3; j++)
            18         for(k=small_y*3; k<(small_y+1)*3; k++)
            19             if(table[j][k]==ch)
            20                 return 0;
            21     return 1;
            22 }
            23 
            24 void
            25 dfs(int x, int y)
            26 {
            27     int i, j, nx, ny;
            28     if(flag)
            29         return;
            30     if(x==9){
            31         if(!flag) {
            32             for(j=0; j<9; j++)
            33                 printf("%s\n", table[j]);
            34             flag = 1;
            35         }
            36         return;
            37     }    
            38     if(y==8) {
            39         nx = x+1;
            40         ny = 0;
            41     } else {
            42         nx = x;
            43         ny = y+1;
            44     }
            45     if(table[x][y] == '0') {
            46         for(i=1; i<=9; i++) {
            47             if(is_available(x, y, i+'0')) {
            48                 table[x][y] = i+'0';
            49                 dfs(nx, ny);
            50                 table[x][y] = '0';
            51             }
            52         }
            53     } else
            54         dfs(nx, ny);
            55 }

            更好的解題代碼見:
            http://blog.csdn.net/logic_nut/archive/2009/08/09/4428996.aspx

            posted on 2010-08-01 08:47 simplyzhao 閱讀(214) 評論(0)  編輯 收藏 引用 所屬分類: B_搜索

            導航

            <2011年10月>
            2526272829301
            2345678
            9101112131415
            16171819202122
            23242526272829
            303112345

            統計

            常用鏈接

            留言簿(1)

            隨筆分類

            隨筆檔案

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            欧美日韩精品久久免费| 中文成人无码精品久久久不卡| 国产69精品久久久久久人妻精品| 亚洲精品国产综合久久一线| 亚洲伊人久久精品影院| 久久国产精品-久久精品| 久久精品亚洲福利| 国产成人精品综合久久久| AV无码久久久久不卡蜜桃| 亚洲国产成人久久一区WWW| 麻豆成人久久精品二区三区免费| 93精91精品国产综合久久香蕉| 一本久久免费视频| 国内精品久久久久国产盗摄| 久久综合精品国产二区无码| 久久综合久久伊人| 成人午夜精品久久久久久久小说| 久久综合噜噜激激的五月天| 中文字幕精品久久| 久久亚洲中文字幕精品一区四| 狠狠色婷婷久久一区二区三区 | 亚洲AV无码久久| 久久精品国产99久久久香蕉| 国产精品久久久福利| 精品永久久福利一区二区| 亚洲AV日韩精品久久久久久| 精品久久久久久无码不卡| 久久se精品一区精品二区国产| 久久综合久久综合久久综合| av午夜福利一片免费看久久 | 91久久精品电影| 精品一区二区久久| 日本精品久久久久中文字幕| 久久国产乱子伦精品免费强| 日本福利片国产午夜久久| 99久久伊人精品综合观看| 久久久久99精品成人片| 精品久久久久久无码人妻热| 久久久久女教师免费一区| 国产精品一区二区久久精品涩爱| 麻豆精品久久久久久久99蜜桃|