2676 Sudoku
Source from: http://acm.pku.edu.cn/JudgeOnline/problem?id=2676
Sudoku中文名“数独”游戏,游戏规则是在一个9×9的方格中填入1-9这9个数字,9×9的大方格又被划分成了9个3×3的小方格,要求填入的这1-9这9个数字中,在每一行,每一列及每一个小方格中都不能重复出现。
在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
飞飞 阅读(702)
评论(0) 编辑 收藏 引用 所属分类:
ACM/ICPC