• <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程序設計
            成長的路……源
            posts - 20,comments - 42,trackbacks - 0
             

            2676 Sudoku

             

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

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

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

            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 飛飛 閱讀(712) 評論(0)  編輯 收藏 引用 所屬分類: ACM/ICPC
            久久er国产精品免费观看2| 久久se精品一区二区影院| 久久人妻少妇嫩草AV蜜桃| 亚洲国产精品综合久久一线| 国产精品久久久香蕉| 久久亚洲精品成人AV| 久久99精品久久久久久野外| 久久无码中文字幕东京热| www.久久99| 亚洲精品无码久久久| 国内精品久久久久| 人妻无码精品久久亚瑟影视| 色综合色天天久久婷婷基地| 免费无码国产欧美久久18| 婷婷综合久久狠狠色99h| 伊人久久五月天| 久久精品成人国产午夜| 久久九九兔免费精品6| 日本道色综合久久影院| 亚洲精品乱码久久久久久久久久久久| 久久精品国产亚洲AV大全| 青春久久| 久久久精品人妻无码专区不卡| 久久99国产综合精品免费| 狠狠色丁香婷婷久久综合五月 | 狠狠综合久久综合88亚洲| 色综合久久久久网| 久久99国内精品自在现线| 亚洲中文字幕久久精品无码喷水| 欧美无乱码久久久免费午夜一区二区三区中文字幕 | 久久久久久曰本AV免费免费| 精品久久久无码中文字幕| 色综合合久久天天综合绕视看 | 久久亚洲熟女cc98cm| 天天影视色香欲综合久久| 久久婷婷五月综合97色直播| 久久综合九色综合久99| 99久久精品费精品国产| 99久久成人18免费网站| 久久久久久青草大香综合精品| 久久精品国产影库免费看|