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

            出處:???? http://acm.hnu.cn:8080/online/?action=problem&type=show&id=11203&courseid=0




            Sudoku
            Time Limit: 1000ms, Special Time Limit:2500ms, Memory Limit:32768KB
            Total submit users: 10, Accepted users: 10
            Problem 11203 : Special judge
            Problem description
            A Sudoku puzzle, once solved, is a 9x9 grid of digits organized as a 3x3 grid of smaller 3x3 units. Each of the nine rows must contain every positive digits exactly once, as do each column and also each 3x3 unit. The puzzle is to start from a partially filled 9x9 grid and to fill in the remaining cells using only logic. The puzzle maker usually makes sure that the solution will be unique and that it can be reached using deduction only, without guessing.

            This number placing game is gaining popularity in the west, and every second newspaper publishes weekly instances of the puzzle. Somewhere at the head of one such newspaper, someone decided that buying individual instances from a puzzle maker would be too expansive, and instead decided to steal puzzles from other newspapers and also to print randomly generated Sudoku-like grids.

            One week later, his assistant gets stuck with the job of printing the solution to the Sudoku puzzles his boss previously published. Unfortunately, his boss doesn’t have those solutions, the randomly generated problems don’t have any solution, and he doesn’t even remember which is which. In despair, the assistant calls for your help.



            Input
            The first line of the input will contain the number of test cases. Each test case will consist of a 9 by 9 grid of characters, where each character will either be ‘?’ or a digit between 1 and 9 inclusively.

            Output
            For each test case, you must print back the grid to the standard input, replacing each question mark with an appropriate digit to solve the Sudoku. If a test case does not allow any solution, output ”impossible” instead of a completed grid. If a test case do allow a solution, you can assume that the solution will be unique, and that theoretically it could be reached without guessing.

            Test cases are separated by “---” both in the input and in the output.

            Sample Input
            3
                        ??4??9??8
                        ?3??5??1?
                        7??4??2??
                        3??8??1??
                        ?5?????9?
                        ??6??1??2
                        ??8??3??1
                        ?2??4??5?
                        6??1??7??
                        ---
                        ??4??9??8
                        ?3??5??1?
                        7??4??2??
                        3??8??1??
                        ?5?????9?
                        ??6??1??2
                        ??8??3??1
                        62??4??5?
                        6??1??7??
                        ---
                        3?1????76
                        7??9?????
                        2?5?3????
                        ?????64?1
                        ???2?1???
                        1?25?????
                        ????8?9?3
                        ?????9??4
                        51????7?8
                        
            Sample Output
            264319578
                        839257416
                        715486239
                        372894165
                        451632897
                        986571342
                        548763921
                        127948653
                        693125784
                        ---
                        impossible
                        ---
                        391452876
                        764918532
                        285637149
                        953876421
                        678241395
                        142593687
                        426785913
                        837169254
                        519324768
                        






            ??1 #include? < iostream >
            ??2
            ??3 using ? namespace ?std;
            ??4
            ??5 bool ?x[ 9 ][ 10 ];
            ??6 bool ?y[ 9 ][ 10 ];
            ??7 bool ?z[ 9 ][ 10 ];
            ??8 int ??result[ 9 ][ 9 ];
            ??9 int ??num = ? 0 ;
            ?10
            ?11
            ?12 int ?GetID(? int ?x,? int ?y?)
            ?13 {
            ?14 ???? if ?(?x < ? 3 ? && ?y < ? 3 ?)
            ?15 ???? return ? 0 ;
            ?16 ???? else ? if ?(?x < ? 3 ? && ?y >= ? 3 ? && ?y < ? 6 ?)
            ?17 ???? return ? 1 ;
            ?18 ???? else ? if ?(?x < ? 3 ? && ?y >= ? 6 ? && ?y < ? 9 ?)
            ?19 ???? return ? 2 ;
            ?20 ???? else ? if ?(?x >= ? 3 ? && ?x < ? 6 ? && ?y < ? 3 ?)
            ?21 ???? return ? 3 ;
            ?22 ???? else ? if ?(?x >= ? 3 ? && ?x < ? 6 ? && ?y >= ? 3 ? && ?y < ? 6 ?)
            ?23 ???? return ? 4 ;
            ?24 ???? else ? if ?(?x >= ? 3 ? && ?x < ? 6 ? && ?y >= ? 6 ? && ?y < ? 9 ?)
            ?25 ???? return ? 5 ;
            ?26 ???? else ? if ?(?x >= ? 6 ? && ?x < ? 9 ? && ?y < ? 3 ?)
            ?27 ???? return ? 6 ;
            ?28 ???? else ? if ?(?x >= ? 6 ? && ?x < ? 9 ? && ?y >= ? 3 ? && ?y < ? 6 ?)
            ?29 ???? return ? 7 ;
            ?30 ???? else ? if ?(?x >= ? 6 ? && ?x < ? 9 ? && ?y >= ? 6 ? && ?y < ? 9 ?)
            ?31 ???? return ? 8 ;
            ?32 }

            ?33
            ?34
            ?35 void ?Print()
            ?36 {
            ?37 ???? for ?(? int ?i = ? 0 ;?i < ? 9 ;? ++ i?)
            ?38 ???? {
            ?39 ???????? for ?(? int ?j = ? 0 ;?j < ? 9 ;? ++ j?)
            ?40 ?????????????printf( " %d " ,result[i][j]?);
            ?41 ????????
            ?42 ???????? if ?(?i < ? 8 ?)?printf( " \n " );
            ?43 ????}

            ?44 }

            ?45
            ?46
            ?47 bool ?GetXY(? int & ?xx,? int & ?yy?)
            ?48 {
            ?49 ???? for ?(? int ?i = ? 0 ;?i < ? 9 ;?i ++ ?)
            ?50 ???? {
            ?51 ???????? for ?(? int ?j = ? 0 ;?j < ? 9 ;?j ++ ?)
            ?52 ???????? if ?(?result[i][j] == ? 0 ?)
            ?53 ???????? {
            ?54 ????????????xx = ?i;
            ?55 ????????????yy = ?j;
            ?56 ????????????
            ?57 ???????????? return ? true ;
            ?58 ????????}

            ?59 ????}

            ?60 ????
            ?61 ???? return ? false ;????
            ?62 }

            ?63
            ?64
            ?65 void ?Try(? int ?xx,? int ?yy?)
            ?66 {
            ?67 ???? for ?(? int ?i = ? 1 ;?i <= ? 9 ;? ++ i?)
            ?68 ???? {
            ?69 ???????? if ?(? ! x[xx][i]? && ? ! y[yy][i]? && ? ! z[?GetID(xx,yy)?][i]?)
            ?70 ???????? {
            ?71 ???????????? int ?a,?b;
            ?72 ????????????
            ?73 ????????????result[xx][yy] = ?i;
            ?74 ????????????
            ?75 ????????????x[xx][i] = ? true ;
            ?76 ????????????y[yy][i] = ? true ;
            ?77 ????????????z[?GetID(xx,yy)?][i] = ? true ;
            ?78 ????????????
            ?79 ???????????? if ?(? ! GetXY(?a,?b?)?)
            ?80 ???????????? {
            ?81 ????????????????Print();
            ?82 ????????????????num = ? 1 ;
            ?83 ???????????????? return ;
            ?84 ????????????}

            ?85 ????????????
            ?86 ????????????Try(?a,?b?);?
            ?87 ????????????result[xx][yy] = ? 0 ;
            ?88 ????????????????
            ?89 ????????????x[xx][i] = ? false ;
            ?90 ????????????y[yy][i] = ? false ;
            ?91 ????????????z[?GetID(xx,yy)?][i] = ? false ;
            ?92 ????????}

            ?93 ????}

            ?94 }

            ?95
            ?96
            ?97
            ?98 int ?main()
            ?99 {
            100 ???? int ?n;
            101 ????scanf( " %d " , & n);
            102 ???? char ?aaa[ 10 ];
            103 ????
            104 ???? for ?(? int ?mm = ? 0 ;?mm < ?n;?mm ++ ?)
            105 ???? {
            106 ???????? char ?graph[ 9 ][ 10 ];
            107 ????????num = ? 0 ;
            108 ????????
            109 ????????memset(?x,? false ,? sizeof (x)?);
            110 ????????memset(?y,? false ,? sizeof (y)?);
            111 ????????memset(?z,? false ,? sizeof (z)?);
            112 ????????memset(?result,? 0 ,? sizeof (?result?)?);
            113 ????????
            114 ???????? for ?(? int ?i = ? 0 ;?i < ? 9 ;? ++ i?)
            115 ?????????????scanf( " %s " ,?graph[i]?);
            116 ?????????????
            117 ???????? for ?(? int ?i = ? 0 ;?i < ? 9 ;? ++ i?)
            118 ???????? {
            119 ???????????? for ?(? int ?j = ? 0 ;?j < ? 9 ;? ++ j?)
            120 ???????????? if ?(?graph[i][j] != ? ' ? ' ?)
            121 ???????????? {
            122 ???????????????? int ?t = ?graph[i][j] - ? ' 0 ' ;
            123 ????????????????result[i][j] = ?t;
            124 ????????????????
            125 ????????????????x[i][t] = ? true ;
            126 ????????????????y[j][t] = ? true ;
            127 ????????????????z[?GetID(?i,?j?)?][t] = ? true ;
            128 ????????????}

            129 ????????}

            130 ????????
            131 ???????? int ?x,?y;
            132 ????????
            133 ????????GetXY(?x,?y?);
            134 ????????Try(?x,?y?);
            135 ?????????????
            136 ???????? if ?(?mm < ?n - ? 1 ?)
            137 ???????? {
            138 ?????????????printf( " \n---\n " );
            139 ?????????????scanf( " %s " ,aaa);
            140 ????????}
            ????
            141 ????????
            142 ???????? if ?(?num == ? 0 ?)
            143 ?????????????printf( " impossible " );
            144 ????}

            145 ????
            146 ???? return ? 0 ;
            147 }

            148 ????????????????
            149
            posted on 2008-08-19 08:14 Darren 閱讀(324) 評論(0)  編輯 收藏 引用 所屬分類: 搜索
            久久精品麻豆日日躁夜夜躁| 久久亚洲AV成人无码国产| 久久精品www人人爽人人| 国内精品伊人久久久久av一坑| AV无码久久久久不卡蜜桃| 成人亚洲欧美久久久久| 久久精品国产亚洲Aⅴ香蕉| 波多野结衣久久一区二区| 97精品伊人久久大香线蕉app| 久久精品无码免费不卡| 亚洲欧洲日产国码无码久久99| www.久久热.com| 久久久久久精品免费看SSS | 996久久国产精品线观看| 激情综合色综合久久综合| 伊人久久大香线蕉av不变影院| 精品999久久久久久中文字幕| 一本久久综合亚洲鲁鲁五月天亚洲欧美一区二区 | 精品综合久久久久久97超人 | 久久精品国产男包| 久久99毛片免费观看不卡| 久久狠狠爱亚洲综合影院| 久久国产成人| 欧美一区二区精品久久| 亚洲αv久久久噜噜噜噜噜| 青青热久久国产久精品| 99久久99久久精品国产| 国产成人久久AV免费| 亚洲精品无码久久久久| 久久亚洲国产成人影院| 久久强奷乱码老熟女| 国内精品伊人久久久久| 久久久一本精品99久久精品66| 狠狠色丁香久久婷婷综合图片 | 亚洲国产另类久久久精品小说| 久久久久99精品成人片| 国产高潮国产高潮久久久91 | 久久福利资源国产精品999| 人妻无码精品久久亚瑟影视| 国产香蕉97碰碰久久人人| 91精品免费久久久久久久久|