gpt4 book ai didi

C数独回溯求解器预检函数

转载 作者:太空宇宙 更新时间:2023-11-04 01:23:45 25 4
gpt4 key购买 nike

这是我在 StackOverflow 上的第一篇文章,所以如果我做错了什么,我深表歉意。我是 C 语言的新手,所以我确信我的代码在某些地方相当丑陋和骇人听闻,但是大部分代码都符合我的预期。我在使用 precheck 方法时遇到问题,该方法在我开始通过我的求解器逻辑输入数独板之前检查它。我正在使用看起来像

的字符串重定向来自文本文件的输入

4.....8.5.34.........7......2.....6.....8.4......1.......6.3.7.5..2.....1.4...... 4.....8.5.3..........7......2.....6.....8.4......1.......6.3.7.5..2.....1.5...... 4.....8.5.3..........7......2.....6.....8.4......1...x...6.3.7.5..2.....1.4...... 417369825632158947958724316825437169791586432346912758289643571573291684164875293 417369825632158947958724316825437169791586432346912758289643.71573291684164875293

每个字符串(理想情况下)为 81 个字符,仅包含数字 1-9 和“.”。我将一个字符串解析为一个临时字符数组,然后使用方法 fillBoard 将临时数组中的字符传输到一个二维 int 数组中。完成后,我将调用我的 precheck 方法。如果填满的棋盘没有通过行、列和方框检查,precheck 方法返回一个 1,表示拼图不可解(意味着应该打印一条错误消息并且程序应该移动到下一个字符串)。出于某种原因,我的 precheck 方法即使对于应该可解析的字符串也会返回一个。我不确定这是为什么。任何帮助,将不胜感激。谢谢。

#include <stdio.h>
#include <string.h>

int alphaError = 0;

struct Point findEmpty(int board[9][9]);
int usedInBox(int board[9][9], int boxStartRow, int boxStartCol, int num);
int positionSafe(int board[9][9], int row, int col, int num);
int usedInCol(int board[9][9], int col, int num);
int usedInRow(int board[9][9], int row, int num);
int solvePuzzle(int board[9][9]);
int precheck(int board[9][9]);

int main()
{
char c;
int charCount = 0;
int i = 0;
char tempStr[100000];
int board[9][9];

while((fscanf(stdin, "%c", &c)) != EOF)
{
printf("%c", c);

if(c != '\n')
{
if(isalpha(c))
{
alphaError = 1;
}

tempStr[i] = c;
i++;
charCount++;
}
else
{
if(charCount != 81 || alphaError == 1)
{
printf("Error\n\n");
i = 0;
charCount = 0;
alphaError = 0;
}
else
{
fillBoard(board, tempStr);
printBoard(board);
if(precheck(board) == 1)
{
printf("Error\n\n");
}
else
{
if(solvePuzzle(board) == 1)
{
printBoard(board);
}
else
{
printf("No solution\n\n");
}
}
i = 0;
charCount = 0;
}
}
}
return 0;
}

struct Point
{
int x;
int y;
} point;

struct Point findEmpty(int board[9][9])
{
struct Point point1;
point1.x = -1;
point1.y = -1;
int row, col;

for(row = 0; row < 9; row++)
{
for(col = 0; col < 9; col++)
{
if(board[row][col] == 0)
{
point1.x = col;
point1.y = row;
}
}
}
return point1;
}

int usedInBox(int board[9][9], int boxStartRow, int boxStartCol, int num)
{
int row, col;

for(row = 0; row < 3; row++)
{
for(col = 0; col < 3; col++)
{
if(board[row + boxStartRow][col + boxStartCol] == num)
{
return 1;
}
}
}
return 0;
}

int positionSafe(int board[9][9], int row, int col, int num)
{
if((usedInRow(board, row, num)) == 0 && (usedInCol(board, col, num)) == 0 && (usedInBox(board, (row-row%3), (col-col%3), num)) == 0)
{
return 1;
}
else
{
return 0;
}
}

int usedInCol(int board[9][9], int col, int num)
{
int row;

for(row = 0; row < 9; row++)
{
if(board[row][col] == num)
{
return 1;
}
}
return 0;
}


int usedInRow(int board[9][9], int row, int num)
{
int col;

for(col = 0; col < 9; col++)
{
if(board[row][col] == num)
{
return 1;
}
}
return 0;
}

int solvePuzzle(int board[9][9])
{
int num;
struct Point point2;

point2 = findEmpty(board);
if(point2.x == -1)
{
return 1;
}

for(num = 1; num <= 9; num++)
{
if(positionSafe(board, point2.y, point2.x, num) == 1)
{
board[point2.y][point2.x] = num;

if(solvePuzzle(board) == 1)
{
return 1;
}

board[point2.y][point2.x] = 0;
}
}
return 0;
}

void printBoard(int board[9][9])
{
int i, j;
for (i = 0; i < 9; i++)
{
for (j = 0; j < 9; j++)
{
printf("%d", board[i][j]);
}
}
printf("\n\n");
}

void fillBoard(int board[9][9], char tempStr[100000])
{
int i, j;
int k = 0;

for(i = 0; i < 9; i++)
{
for(j = 0; j < 9; j++)
{
if(tempStr[k] == '.')
{
board[i][j] = 0;
}
else
{
board[i][j] = (tempStr[k] - '0');
}
k++;
}
}
}

int precheck(int board[9][9])
{
int i, j, num;

for(i = 0; i < 9; i++)
{
for(j = 0; j < 9; j++)
{
if(board[i][j] != 0)
{
num = board[i][j];
if(positionSafe(board, i, j, num) == 0)
{
return 1;
}
}
}
}
return 0;
}

最佳答案

那么您是在已经填满的棋盘上使用 precheck 吗?这可能是问题所在,因为如果值已经存在,usedInColusedInRowusedInBlock 将返回 1。所以 precheck 应该只在填充板时使用,而不是之后使用。如果您检查从已填满的棋盘中获取的值,它将始终返回 1。

关于C数独回溯求解器预检函数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35695090/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com