⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 sequentialpuzzlesolver.java

📁 java concurrency in practice 源码. JAVA并发设计
💻 JAVA
字号:
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 + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -