这次版本存在瑕疵,给用户填写的数独有不唯一解的可能,这将会在以后改进
var sudoku=[
[0,0,0,0,0,0,0,0,0],
[0,0,0,0,0,0,0,0,0],
[0,0,0,0,0,0,0,0,0],
[0,0,0,0,0,0,0,0,0],
[0,0,0,0,0,0,0,0,0],
[0,0,0,0,0,0,0,0,0],
[0,0,0,0,0,0,0,0,0],
[0,0,0,0,0,0,0,0,0],
[0,0,0,0,0,0,0,0,0],
];
function generateSudoku(){
for(var i=1;i<10;i++){
for(var j=0;j<9;j++){
//把数字i填入第j个小九宫格中
fillNumberInOneArray(i,j);
}
}
}
①执行collectNumPosition(num,n)
收集数字num在第n个九宫格上可以填入的位置
②执行flashBack(num,n)
当数字num在第n个小九宫格上没有可以填入的位置时执行
①判断num在该行是否已填过
②判断num在该列上是否已填过
③判断该位置上是否有其他数字
④存入数组numPosition中
①依次提取数组numPosition中的元素
②将导致程序无法进行的元素删除,直到找到合适的位置
根据用户选择的难度系数来决定要挖掉的格子数blank
随机生成blank个位置
在页面上渲染出除这bank个位置外,其他位置上的数字
将用户填入的数字存到数组userAnswer中
将userAnswer与sudoku进行对比
相同的显示为蓝色,不同的保留错误答案,并以红色显示