c -二维阵列澄清



目前我有麻烦,让我的代码工作,其中检查数独板后,它被分配了一个新的值,以不插槽,然后看看它是否仍然块有效或不。

目前,即使我输入了正确的输入,这段代码仍然告诉我,我的块是无效的。

tempsudoku板基本上是一个数独板,0随机槽表示空白。有人可以看到,如果我做错了我的代码?

int truefalse=1;
printf("Enter a row (1-9), column (1-9) and number (1-9), separated by spaces: ");
scanf("%d %d %d", &row, &column, &number);
tempsudoku[row-1][column-1]=number;
for(i=0;i<=2;i++)
{
    for(j=0;j<=2;j++)
    {
        int check[9]={0};
        for(x=0;x<=(j*3)+2;x++)
        {
            for(y=0;y<=(i*3)+2;y++)
            {
                for(k=0;k<=8;k++)
                {
                    if(tempsudoku[x][y]==k+1)
                    {
                        check[k]++;
                    }
                }
            }
        }
        for(k=0;k<=8;k++)
        {
            if(check[k]>=2)
            {
                printf("Error: repeats in boardn");
                truefalse=0;//basically means  its false
            }
        }
    }
}
for(x=0;x<=(j*3)+2;x++){
   for(y=0;y<=(i*3)+2;y++){

应该是

for(x=3*j;x<=(j*3)+2;x++){
   for(y=i*3;y<=(i*3)+2;y++){

遍历一个块的九个单元格。


注意你可以简化

for(k=0;k<=8;k++){
    if(tempsudoku[x][y]==k+1){
        check[k]++;
    }
}

k = tempsudoku[x][y];
if (k >= 1)
    check[k-1]++;

相关内容

  • 没有找到相关文章

最新更新