• <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>
            alpc60 ACM/ICPC程序設(shè)計
            成長的路……源
            posts - 20,comments - 42,trackbacks - 0
             

            2676 Sudoku

             

            Source from http://acm.pku.edu.cn/JudgeOnline/problem?id=2676

            Sudoku中文名“數(shù)獨”游戲,游戲規(guī)則是在一個9×9的方格中填入199個數(shù)字,9×9的大方格又被劃分成了93×3的小方格,要求填入的這199個數(shù)字中,在每一行,每一列及每一個小方格中都不能重復(fù)出現(xiàn)。

            pku上,我暴搜的方法,將每個空格的位置幾下,然后用dfs往里填數(shù),不符合條件的就回溯。方法如下:

            Source

             

            Problem: 2676 User: alpc60

            Memory: 80K Time: 1171MS

            Language: C++ Result: Accepted

             

            Source

            #include <stdio.h>

            #include <string.h>

             

            struct P

            {

                   int x,y,num;

            }point[100];

            int map[10][10],count;

            bool mr[10][10],mc[10][10],mm[10][10];

             

            int dfs(int n);

            int find(int x, int y);

             

            int main()

            {

                   int i,j,cases;

                   //freopen("2676.txt","r",stdin);

                   scanf("%d",&cases);

                   while(cases--)

                   {

                          count=0;

                          memset(mc,false,sizeof(mc));

                          memset(mr,false,sizeof(mr));

                          memset(mm,false,sizeof(mm));

                          memset(map,0,sizeof(map));

                          for(i=1; i<=9; i++)

                                 for(j=1; j<=9; j++)

                                 {

                                        scanf("%1d",&map[i][j]);

                                        if(map[i][j]==0)

                                        {

                                               point[count].x=i;

                                               point[count].y=j;

                                               point[count].num=0;

                                               count++;

                                        }

                                        else

                                        {

                                               mr[i][map[i][j]]=true;

                                               mc[j][map[i][j]]=true;

                                               mm[find(i,j)][map[i][j]]=true;

                                        }

                                 }

                          dfs(0);

                          //{

                                 for(i=0; i<count; i++)

                                        map[point[i].x][point[i].y]=point[i].num;

                                 for(i=1; i<=9; i++)

                                 {

                                        for(j=1; j<=9; j++)

                                        {

                                               printf("%d",map[i][j]);

                                        }

                                        printf("\n");

                                 }

                          //}

                   }

                   return 0;

            }

            int dfs(int n)

            {

                   int i,t;

                   if(n>=count)

                          return 1;

                   t=find(point[n].x,point[n].y);

                   for(i=1; i<=9; i++)

                   {

                          if(!mr[point[n].x][i] && !mc[point[n].y][i] && !mm[t][i])

                          {

                                 mr[point[n].x][i]=true;

                                 mc[point[n].y][i]=true;

                                 mm[t][i]=true;

                                 point[n].num=i;

                                 if(dfs(n+1))

                                        return 1;

                                 mr[point[n].x][i]=false;

                                 mc[point[n].y][i]=false;

                                 mm[t][i]=false;

                                 point[n].num=0;

                          }

                   }

                   return 0;

            }

            int find(int x, int y)

            {

                   int r,c;

                   r=x%3?(x/3+1):(x/3);

                   c=y%3?(y/3+1):(y/3);

                   return (r-1)*3+c;

            }

            posted on 2007-09-23 15:29 飛飛 閱讀(720) 評論(0)  編輯 收藏 引用 所屬分類: ACM/ICPC
            久久99精品久久久久久久久久| 国产99久久精品一区二区| 精品一区二区久久久久久久网站| 国产精品久久毛片完整版| 97精品伊人久久久大香线蕉| 日韩精品无码久久一区二区三| 伊人久久久AV老熟妇色| 国产精品毛片久久久久久久| 伊人色综合久久天天人守人婷| 久久成人精品视频| 亚洲精品无码久久久久久| 久久久久亚洲精品男人的天堂 | 久久久久亚洲精品男人的天堂| 久久婷婷五月综合成人D啪| 精品综合久久久久久888蜜芽| 亚洲国产精品一区二区三区久久| 狠狠色丁香久久综合婷婷| 亚洲国产美女精品久久久久∴ | 精品欧美一区二区三区久久久| 日韩人妻无码精品久久免费一| 武侠古典久久婷婷狼人伊人| 精品国产综合区久久久久久| 一本伊大人香蕉久久网手机| 91久久婷婷国产综合精品青草| 亚洲国产精品高清久久久| 婷婷久久综合九色综合九七| 国产精品免费久久| 91精品国产91久久久久久青草| 久久精品国产亚洲综合色| 久久国产高清字幕中文| 无码国内精品久久人妻| 久久久久久久久久久| 久久久久国产精品嫩草影院| 中文字幕日本人妻久久久免费 | 中文字幕久久久久人妻| 久久精品国产久精国产一老狼| 国产成人无码精品久久久性色| 久久91精品国产91久| 久久精品国产久精国产果冻传媒 | 国产精品免费久久久久久久久| 99久久www免费人成精品|