数独求解器,检查每个3x3盒子

Jos*_*ith 0 matlab

简而言之,我正在检查每个3x3盒子,如果有一个缺失值,如果有,则计算该数字是什么,然后填入该数字.但是,它只做左上角3x3盒子,然后停在那里.以下是与我的问题相关的代码片段.如果你想看到剩下的代码,我会发布剩下的代码.

编辑:用户输入电路板.出于测试目的,我尝试输入完整的数独谜题,然后在每个框中取出右上角的值.它只填充了第一个3x3,它仍然在最后输出板,但还有8个其他空白要填写(从其他8个3x3盒)

% Check each 3x3 box for one through nine, fill in
for i = 0:2
    for j = 0:2
        if sum(sum(board([1:3]+i*3,[1:3]+j*3)~=0))==8
            [row,col] = find(board([1:3]+i*3,[1:3]+j*3)==0);
            answer = 45 - sum(sum(board([1:3]+i*3,[1:3]+j*3)));
            board(row,col) = answer;
        end
    end
end
disp(board);
Run Code Online (Sandbox Code Playgroud)

Thi*_*jsW 5

你很近.问题是,对于每个块,您将获得3x3块的行和列索引.因此,对于每个块,以下是真实的:row <= 3col <= 3.

您可以通过在您使用的行之后添加这两行来轻松解决此问题find:

row = row + (3*i);
col = col + (3*j);
Run Code Online (Sandbox Code Playgroud)

这样您就可以将块相对索引转换回与板相关的索引.