Middle-题目119:127. Word Ladder

原创 2016年05月31日 20:10:25

题目原文:
Given two words (beginWord and endWord), and a dictionary’s word list, find the length of shortest transformation sequence from beginWord to endWord, such that:
Only one letter can be changed at a time
Each intermediate word must exist in the word list
For example,
Given:
beginWord = “hit”
endWord = “cog”
wordList = [“hot”,”dot”,”dog”,”lot”,”log”]
As one shortest transformation is “hit” -> “hot” -> “dot” -> “dog” -> “cog”,
return its length 5.
题目大意:
给出两个单词beginWord和endWord,和一个字典,求出从beginWord到endWord的最短转换序列,要求中间单词必须是字典中的,且每次只能转换一个字母。
题目分析:
表面上看是一个单源最短路径问题,博客中说这道题的test case和题目要求都有问题,所以我也就没做,以下只贴出ac代码。
源码:(language:java)

public class Solution {

    public int ladderLength(String beginWord, String endWord, Set<String> wordList) {
        Set<String> beginSet = new HashSet<String>(), endSet = new HashSet<String>();

        int len = 1;
        int strLen = beginWord.length();
        HashSet<String> visited = new HashSet<String>();

        beginSet.add(beginWord);
        endSet.add(endWord);
        while (!beginSet.isEmpty() && !endSet.isEmpty()) {
            if (beginSet.size() > endSet.size()) {
                Set<String> set = beginSet;
                beginSet = endSet;
                endSet = set;
            }

            Set<String> temp = new HashSet<String>();
            for (String word : beginSet) {
                char[] chs = word.toCharArray();

                for (int i = 0; i < chs.length; i++) {
                    for (char c = 'a'; c <= 'z'; c++) {
                        char old = chs[i];
                        chs[i] = c;
                        String target = String.valueOf(chs);

                        if (endSet.contains(target)) {
                            return len + 1;
                        }

                        if (!visited.contains(target) && wordList.contains(target)) {
                            temp.add(target);
                            visited.add(target);
                        }
                        chs[i] = old;
                    }
                }
            }

            beginSet = temp;
            len++;
        }

        return 0;
    }
}

成绩:
47ms,beats 89.34%,众数97ms,2.42%
Cmershen的碎碎念:
据说后面的word ladder 2这道题也是有问题的。

版权声明:完整版Leetcode题解请出门左转https://github.com/cmershen1/leetcode/tree/master/docs

LeetCode 127 Word Ladder java (看某位大神的解法做出来的)

问题重述: Given two words (beginWord and endWord), and a dictionary’s word list, find the length of sh...
  • qq_16166139
  • qq_16166139
  • 2016年04月21日 21:50
  • 960

127. Word Ladder 单词间的最短路径

Given two words (beginWord and endWord), and a dictionary's word list, find the length of shortest t...
  • u010005161
  • u010005161
  • 2016年07月31日 15:27
  • 208

单词变换路径 Word Ladder II

这一问题是《单词变换距离 Word Ladder (无权图的最短路径)   》的引申问题。 Given two words (start and end), and a dictionary...
  • luckyjoy521
  • luckyjoy521
  • 2014年04月02日 17:09
  • 2107

leetcode解题之127. Word Ladder Java版 (单词等长变换)

leetcode解题之127. Word Ladder Java版 (单词等长变换)
  • mine_song
  • mine_song
  • 2017年04月02日 14:21
  • 561

[LeetCode]127. Word Ladder 深入浅出讲解和代码示例

在LeetCode的word ladders解题思路中,用到了哈希、堆栈的知识点。
  • karen0310
  • karen0310
  • 2017年07月12日 14:55
  • 111

Word Ladder(单词阶梯)

题目来源 Given two words (beginWord and endWord), and a dictionary's word list, find the length of sho...
  • lemonpi
  • lemonpi
  • 2017年12月09日 15:05
  • 29

word ladder 2 的复杂实现

采用分治法的思想。 (1)把所有两数之和计算出来,并保存在multimap中。放在unordered_multimap中的效率更高,但是因为其采用hash定位元素的方法,导致map中的数据不能按序索...
  • ylzintsinghua
  • ylzintsinghua
  • 2014年12月04日 12:35
  • 225

基于Word文档的试卷单题拆分工具

几年前一个csdn上遇到一个朋友咨询“基于Word文档的试卷单题拆分”的问题,正好当时做完了这样一个工具,效果不错。当时分享了一些设计思路,留下了联系方式,几年来不少朋友又在询问这一问题,或多或少又做...
  • yangminghua
  • yangminghua
  • 2016年07月15日 18:46
  • 1079

算法细节系列(20):Word Ladder系列

算法细节系列(20):Word Ladder系列 详细代码可以fork下Github上leetcode项目,不定期更新。 题目摘自leetcode: 1. Leetcode 127: Word ...
  • u014688145
  • u014688145
  • 2017年05月18日 15:07
  • 464

【广度优先遍历】Word Ladder II

题目:leetcode Word Ladder II   Given two words (start and end), and a dictionary, find al...
  • bupt8846
  • bupt8846
  • 2015年04月07日 10:21
  • 392
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Middle-题目119:127. Word Ladder
举报原因:
原因补充:

(最多只允许输入30个字)