我可以解决一个简单的难题,但尝试稍微难一点的难题是不可能的;我在看什么?这是我的求解器方法:
int solver (int x, int y)
{
int a, b, i, j;
for (a=1; a<10; a++)
{
if (checkEverything(x, y, a))
{
board[x][y] = a;
counter++;
if (counter == 81)
{
return true;
}
if (x == 9)
{
return true;
}
if (counter > 200 || counter < -10) {
return false;
}
for (i=0; i<9; i++)
{
for (j=0; j<9; j++)
{
if (board[i][j] == 0)
{
if (solver(i, j))
{
return true;
}
}
}
}
counter--;
}
}
board[x][y] = 0;
return false;
}
我的 checkEverything 函数检查以确保给定的数字可以安全地放置在行、列和 3x3 网格中……我很迷茫,因为它似乎对我来说是正确的,但它太慢了。谢谢你的帮助!