延迟递归回溯的java(Delay recursive backtracking java)

2019-10-17 17:31发布

我发现它使用回溯,当它试图解决这一难题,并为更好的理解,我想拖延这一进程,所以我可以分析回溯这个数独解算器。 但我真的不知道该怎么做。 我试图使用Thread.sleep(100); 但我真的不知道哪儿放延迟。

abstract class SudoKiller {
    private SudokuBoard sb;    // Puzzle to solve;

    public SudoKiller(SudokuBoard sb) {
        this.sb = sb;
    }


    private boolean check(int num, int row, int col) {
        int r = (row / sb.box_size) * sb.box_size;
        int c = (col / sb.box_size) * sb.box_size;

        for (int i = 0; i < sb.size; i++) {
            if (sb.getCell(row, i) == num ||
                    sb.getCell(i, col) == num ||
                    sb.getCell(r + (i % sb.box_size), c + (i / sb.box_size)) == num) {
                return false;
            }
        }
        return true;
    }


    public boolean guess(int row, int col) {
        int nextCol = (col + 1) % sb.size;
        int nextRow = (nextCol == 0) ? row + 1 : row;

        try {
            if (sb.getCell(row, col) != sb.EMPTY)
                return guess(nextRow, nextCol);
        }
        catch (ArrayIndexOutOfBoundsException e) {
            return true;
        }

        for (int i = 1; i <= sb.size; i++) {
            if (check(i, row, col)) {
                sb.setCell(i, row, col);
                if (guess(nextRow, nextCol)) {
                    return true;
                }
            }
        }
        sb.setCell(sb.EMPTY, row, col);
        return false;
    }
}

整个项目上可以找到作者的网站 。

Answer 1:

如何在这里:

sb.setCell(i, row, col);
Thread.sleep(100);
if (guess(nextRow, nextCol)) {

注意sleep有需要处理的(即使不是抛出)异常,所以最简单的解决方案:

sb.setCell(i, row, col);
try { Thread.sleep(100); } catch(InterruptedException e) {}
if (guess(nextRow, nextCol)) {

那是:

  • 后一set
  • 递归调用之前

上述的任一种或两种通常是良好的候选者(视情况而定)。

你甚至可以把它放在里面 setCell方法。



文章来源: Delay recursive backtracking java