repo: github.com/emilytimer/…
play: emilytimer.github.io/sudoku/
规则
玩家需要根据9×9盘面上的已知数字,推理出所有剩余空格的数字,并满足每一行、每一列、每一个粗线宫(3*3)内的数字均含1-9,不重复。
思路
生成满足条件的九宫格,然后随机去掉些空格,当最后1个空格填上时,验证结果
生成回文
横纵乱序
- 横向
- 九宫格内: 将1-3行乱序,可为3-1-2,或者2-1-3,不会影响结果。同理,再将4-6乱序,7-9乱序。
- 九宫格间: 再将3个九宫格乱序,如7-9放最前面,1-3次之,4-6再次之。
- 纵向:同理
将乱序后的数组记录为answer数组,用于最终验证。
随机留空
根据难度系数,设定概率,随机选择空格留空
function emptyFlag(level) {
let chance;
switch (level) {
case 'easy':
chance = 0.6;
break;
case 'middle':
chance = 0.5;
break;
case 'hard':
chance = 0.3;
}
return Math.random() > chance
}
easy模式,40%的单元格是空的,hard模式,70%的单元格是空的 
用户输入
let v = $(this).val() //用户输入的值
if(isNaN(v)){ //如果不是数字
$(this).val('')
return false;
}
if(v.toString().length>0){ //如果连续输入数字
v = v.toString().slice(-1)
}
$(this).val(v)
检查结果
当最后1个空格填上时候,验证数独是否成立。 将前面我们存的answer数组和用户填后的数组比较得出结果。

