• <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
            国产精品久久久亚洲| 久久亚洲国产成人影院| 久久99国产精品久久久| 国产精品VIDEOSSEX久久发布| 精品久久久久中文字幕日本| 国产精品无码久久四虎| 亚洲AV无码久久| 久久久久亚洲精品中文字幕| 久久精品国产亚洲AV蜜臀色欲| 丰满少妇高潮惨叫久久久| 香蕉久久一区二区不卡无毒影院| 女人高潮久久久叫人喷水| 久久夜色tv网站| 久久久久久精品免费免费自慰| 大美女久久久久久j久久| 久久棈精品久久久久久噜噜| 久久久久亚洲精品中文字幕| 久久精品国产69国产精品亚洲| 久久久久免费精品国产| 久久这里只有精品久久| 蜜臀av性久久久久蜜臀aⅴ| 欧美激情精品久久久久久久九九九| 国产精品对白刺激久久久| 午夜精品久久久久| 伊人色综合久久天天人守人婷| 精品国产综合区久久久久久| 国产亚洲美女精品久久久久狼| 久久精品国产亚洲AV无码麻豆 | 欧美久久久久久精选9999| 久久国产精品一国产精品金尊| 久久受www免费人成_看片中文 | 久久夜色撩人精品国产| 色综合久久最新中文字幕| 日韩久久久久久中文人妻| 亚洲欧洲久久久精品| 久久精品蜜芽亚洲国产AV| 国产亚洲色婷婷久久99精品91| 亚洲国产另类久久久精品| 漂亮人妻被中出中文字幕久久| 久久精品亚洲精品国产色婷| 伊人久久大香线蕉AV一区二区|