zoukankan      html  css  js  c++  java
  • Leetcode 17.22单词转换 dfs+回溯+剪枝

      JAVA:

    public final List<String> findLadders(String beginWord, String endWord, List<String> wordList) {
            List<String> re = new LinkedList<String>();
            Set<String> set = new HashSet<>(), his = new HashSet<>();
            boolean exit = dfs(re, set, his, beginWord, endWord, wordList);
            if (exit) re.add(0, beginWord);
            return re;
        }
    
        private final boolean dfs(List<String> re, Set<String> set, Set<String> his, String curr, String endWord,
                                  List<String> wordList) {
            for (int i = 0; i < wordList.size(); i++) {
                String next = wordList.get(i);
                if (set.contains(next) || !this.canBeNext(curr, next) || his.contains(curr)) continue;
                set.add(next);
                re.add(next);
                if (next.equals(endWord) || dfs(re, set, his, next, endWord, wordList)) return true;
                set.remove(next);
                re.remove(re.size() - 1);
                his.add(next);
            }
            return false;
        }
    
        private final boolean canBeNext(String pre, String next) {
            int len = pre.length(), diff = 0;
            for (int i = 0; i < len; i++) {
                if (pre.charAt(i) != next.charAt(i)) {
                    if (diff == 0) diff++;
                    else return false;
                }
            }
            return diff == 0 ? false : true;
        }

      JS:

    /**
     * @param {string} beginWord
     * @param {string} endWord
     * @param {string[]} wordList
     * @return {string[]}
     */
    var findLadders = function (beginWord, endWord, wordList) {
        let re = [];
        let hasRe = dfs(re, beginWord, new Set(), new Set(), endWord, wordList);
        if (hasRe) re.unshift(beginWord);
        return re;
    };
    
    var dfs = function (re, curr, set, his, endWord, wordList) {
        for (let i = 0; i < wordList.length; i++) {
            let next = wordList[i];
            if (set.has(next) || his.has(next) || !canBeNext(curr, next)) continue
            set.add(next);
            his.add(next);
            re.push(next);
            if (next == endWord || dfs(re, next, set, his, endWord, wordList)) return true;
            set.delete(next);
            re.pop();
        }
        return false;
    }
    
    var canBeNext = function (pre, next) {
        if (!pre || !next) return false;
        let len = pre.length, diff = 0;
        for (let i = 0; i < len; i++) {
            if (pre.charAt(i) != next.charAt(i)) {
                if (diff == 0) diff++;
                else return false;
            }
        }
        return diff == 1;
    }

    当你看清人们的真相,于是你知道了,你可以忍受孤独
  • 相关阅读:
    集合的代数运算
    集合的代数运算
    poj1639 Picnic Planning,K度限制生成树
    C/C++学习站点资源
    Mustache 使用心得总结
    PostgreSQL服务端监听设置及client连接方法
    【线性规划与网络流24题】汽车加油行驶问题 分层图
    linux系统下信号具体解释2
    【数据结构】栈-数组的实现
    EJB究竟是什么,真的那么神奇吗??
  • 原文地址:https://www.cnblogs.com/niuyourou/p/14881588.html
Copyright © 2011-2022 走看看