sequentialpuzzlesolver.java

来自「java concurrency in practice 源码. JAVA」· Java 代码 · 共 42 行

JAVA
42
字号
package net.jcip.examples;import java.util.*;/** * SequentialPuzzleSolver * <p/> * Sequential puzzle solver * * @author Brian Goetz and Tim Peierls */public class SequentialPuzzleSolver <P, M> {    private final Puzzle<P, M> puzzle;    private final Set<P> seen = new HashSet<P>();    public SequentialPuzzleSolver(Puzzle<P, M> puzzle) {        this.puzzle = puzzle;    }    public List<M> solve() {        P pos = puzzle.initialPosition();        return search(new PuzzleNode<P, M>(pos, null, null));    }    private List<M> search(PuzzleNode<P, M> node) {        if (!seen.contains(node.pos)) {            seen.add(node.pos);            if (puzzle.isGoal(node.pos))                return node.asMoveList();            for (M move : puzzle.legalMoves(node.pos)) {                P pos = puzzle.move(node.pos, move);                PuzzleNode<P, M> child = new PuzzleNode<P, M>(pos, move, node);                List<M> result = search(child);                if (result != null)                    return result;            }        }        return null;    }}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?