早就感觉这一题很有意思,一直迫于麻烦没有写,今天下午花了将近三个小时AC掉了,呵呵,以后就不怕这样的数独了。
大致思路:用一个结构体s,将每一个‘?’的位置信息记录,以备后面DFS。
对s中的每一个元素进行遍历,即对每一个‘?’号遍历。
每个‘?’号处试着放入1-9的数并检查这个数是否符合要求。即,检查一行,一列以及一个3×3方格内是否有相同的数。
刚开始,每组个实例后输出一个空格后说是表达错误,应该是最后一组实例多输入空格了吧!
1 #include<iostream> 2 #include<cstring> 3 #include<cstdio> 4 using namespace std; 5 struct node 6 { 7 int x,y; 8 }s[81]; 9 int ans[10][10]; 10 int num; 11 bool flag; 12 bool canput(int x,int y,int data) 13 { 14 15 int i,j; 16 for(i=0;i<9;i++)//检查列 17 { 18 if(i==x) continue; 19 if(ans[i][y]==data) return false; 20 } 21 for(j=0;j<9;j++)//检查行 22 { 23 if(j==y) continue; 24 if(ans[x][j]==data) return false; 25 } 26 int xx,yy,xxx,yyy;//每个3×3方格内有无重复数 27 xx=x/3*3;yy=y/3*3; 28 xxx=xx+3;yyy=yy+3; 29 for(i=xx;i<xxx;i++) 30 for(j=yy;j<yyy;j++) 31 { 32 if(x==i&&y==j) continue; 33 if(ans[i][j]==data) 34 return false; 35 } 36 37 return true; 38 39 } 40 void DFS(int k) 41 { 42 if(flag==true) return ; 43 if(num==k) 44 { 45 flag=true; 46 return ; 47 } 48 int i; 49 for(i=1;i<=9;i++) 50 { 51 if(canput( s[k].x, s[k].y, i )==true) 52 { 53 ans[s[k].x][s[k].y]=i; 54 DFS(k+1); 55 if(flag) return ; 56 else 57 ans[s[k].x][s[k].y]=0; 58 } 59 60 } 61 } 62 int main() 63 { 64 //freopen("input.txt","r",stdin); 65 //freopen("output.txt","w",stdout); 66 char s1[5]; 67 int c=0; 68 while(scanf("%s",s1)!=EOF) 69 { 70 num=0; 71 flag=false; 72 if(s1[0]!='?') 73 ans[0][0]=s1[0]-'0'; 74 else 75 { 76 s[num].x=0;s[num].y=0; 77 ans[0][0]=0; 78 num++; 79 } 80 int i,j; 81 for(i=0;i<9;i++) 82 { 83 for(j=0;j<9;j++) 84 { 85 if(i==0&&j==0) continue; 86 char str[5]; 87 scanf("%s",str); 88 if(str[0]=='?') 89 { 90 s[num].x=i;s[num].y=j; 91 ans[i][j]=0; 92 num++; 93 } 94 else 95 ans[i][j]=str[0]-'0'; 96 } 97 } 98 DFS(0); 99 if(c++) printf("\n");//这个地方只要求两组实例间输出一个空格 100 for(i=0;i<9;i++) 101 for(j=0;j<9;j++) 102 if(j==0) 103 printf("%d",ans[i][j]); 104 else if(j==8) 105 printf(" %d\n",ans[i][j]); 106 else 107 printf(" %d",ans[i][j]); 108 109 110 } 111 return 0; 112 }