• <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 飛飛 閱讀(707) 評論(0)  編輯 收藏 引用 所屬分類: ACM/ICPC
            亚洲精品tv久久久久| 国产精品内射久久久久欢欢| 久久这里只有精品首页| 中文字幕日本人妻久久久免费| 亚洲精品午夜国产VA久久成人| 久久精品无码一区二区无码| 99久久99久久精品国产| 亚洲精品无码成人片久久| 99久久精品国产高清一区二区| 久久久久久久综合综合狠狠| 国内精品久久久久久99| 久久久久这里只有精品 | 精品国产热久久久福利| 亚洲国产精品无码成人片久久| 国产精品无码久久久久| 精品熟女少妇av免费久久| 中文精品99久久国产 | 久久综合九色综合欧美就去吻| 国产精品女同久久久久电影院 | 无码人妻久久久一区二区三区| 久久乐国产精品亚洲综合| 久久久久人妻一区精品性色av| 一本久久精品一区二区| 久久久久国色AV免费观看| 久久九九有精品国产23百花影院| 日本欧美久久久久免费播放网| 一本色道久久综合| 久久久午夜精品福利内容| 久久人人爽人人澡人人高潮AV| 精品乱码久久久久久夜夜嗨 | 2021国产精品午夜久久| 日本精品久久久久久久久免费| 久久成人18免费网站| 久久精品18| 久久午夜免费视频| 久久精品日日躁夜夜躁欧美| 久久午夜免费视频| 久久夜色精品国产噜噜麻豆| 久久国产精品久久国产精品| 久久免费高清视频| 久久婷婷五月综合成人D啪|