#include <stdio.h>
#define N 9
void init(char a[N][N]){
int i, j;
char temp;
FILE *fp = fopen("data.txt", "r");
for(i = 0; i < N; i++)
for(j = 0; j < N; j++)
{
fscanf(fp, "%c", &temp); //读书文件中的初始数据,符号 . 代表空格子
if(((temp > 48) && (temp < 58))|| (temp == '.'))
a[i][j] = temp;
else
j--;
}
fclose(fp);
}
void print(char a[N][N])
{
int i, j;
for(i = 0; i < N; i++)
{
for(j = 0; j < N; j++)
{
printf("%c ",a[i][j]);
if((j == 2) || (j == 5))
printf(" ");
}
printf("\n");
if((i == 2) || (i == 5))
printf("\n");
}
printf("\n");
}
int judge(char a[N][N], int i, int j, int k) //判断第i行 第j列是否可以为k
{
int m, n;
int t1 =(i / 3) * 3, t2 = (j / 3) * 3;
for(n = 0; n < N; n++) //判断行
{
if(a[i][n] == k)
return 0;
}
for(m = 0; m < N; m++) //判断列
{
if(a[m][j] == k)
return 0;
}
for(m = t1; m < t1 + 3; m++) //判断小九宫格
{
for(n = t2; n < t2 + 3; n++)
{
if(a[m][n] == k)
return 0;
}
}
return -1;
}
void travelsal(char a[N][N], int p) //遍历,p为坐标
{
char temp[N][N];
int i, j, k, flag;
for(i = 0; i < N; i++)
{
for(j = 0; j < N; j++)
{
temp[i][j] = a[i][j];
}
}
i = p / N; //求第p个数的行数,列数
j = p % N;
if(a[i][j] != '.') //有原始数据
{
if(p == (N * N - 1)) //是否是最后一个数
print(temp);
else
travelsal(temp, p + 1); //不是最后一个数就遍历下一个数
}
else //无原始数据
{
for(k = 1; k <= N; k++)
{
flag = judge(temp, i, j, k);
if(flag)
{
temp[i][j] = k + '0'; //转换为字符型
if(p == (N * N - 1))
print(temp);
else
travelsal(temp, p + 1);
temp[i][j] = '.';
}
}
}
}
int main(){
char a[N][N];
init(a);
print(a);
travelsal(a, 0);
return 0;
}