`

Word Ladder

阅读更多
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.

Note:
Return 0 if there is no such transformation sequence.
All words have the same length.
All words contain only lowercase alphabetic characters.

给定两个单词和一个单词集合,从一个单词变换到另一个单词,每次只能改变一个字母,并且变换后的单词都要在单词集合中,找出最少的变换次数。我们从beginWord开始,每个字符都可能有26种变换,我们用一个set来记录在wordlist中已经被访问过的单词,用path来记录走过的长度,如果变换后的单词与endword相同就返回path+1,如果不相同,看是否在wordlist中并且检查是否被访问过,然后更新beginSet,直到找到一条路,或者beginSet为空,返回0。代码如下:
public class Solution {
    public int ladderLength(String beginWord, String endWord, Set<String> wordList) {
        Set<String> beginSet = new HashSet<String>();
        Set<String> isVisited = new HashSet<String>();
        beginSet.add(beginWord);
        int path = 1;
        while(!beginSet.isEmpty()) {
            Set<String> tem = new HashSet<String>();
            for(String word : beginSet) {
                char[] c = word.toCharArray();
                for(int i = 0; i < c.length; i++) {
                    char oldChar = c[i];
                    for(char j = 'a'; j <= 'z'; j++) {
                        c[i] = j;
                        String s = new String(c);
                        if(s.equals(endWord))
                            return path + 1;
                        if(wordList.contains(s) && !isVisited.contains(s)) {
                            tem.add(s);
                            isVisited.add(s);
                        }
                    }
                    c[i] = oldChar;
                }
            }
            beginSet = tem;
            path ++;
        }
        return 0;
    }
}
0
0
分享到:
评论

相关推荐

    Stanford WordLadder and Randomwriter

    标题中的“Stanford WordLadder”和“Randomwriter”是两个特定的程序或工具,它们在IT领域,尤其是自然语言处理(NLP)方面有一定的应用。让我们分别详细探讨这两个概念。 **Stanford WordLadder** Stanford Word...

    word ladder

    经典字梯游戏c++代码,经测试通过的哦,leetcode上面的题目

    word_ladder

    word_ladder问题源代码 算法导论

    126.Word Ladder II 词语阶梯二【LeetCode单题讲解系列】

    126.Word_Ladder_II_词语阶梯二【LeetCode单题讲解系列】

    BluePrism.WordLadder

    《C#实现BluePrism.WordLadder:探索图算法在解决文字阶梯问题中的应用》 在信息技术领域,算法是解决问题的关键工具,而C#作为一款强大的编程语言,常常被用来实现各种复杂算法。本篇文章将深入探讨一个名为"Blue...

    word源码java-wordladder3-user-authenticating:wordladder使用sping对用户进行身份验证

    Ladder with authenticating user 1. 实现spring security的四种方法 1. 全部利用配置文件 不使用数据库,全部信息写在配置文件中,如拦截的URL及对应权限,指定用户名、密码和对应权限 2. 数据库+配置文件 数据库...

    wordLadder_web

    【标题】"wordLadder_web"是一个基于Web的程序,可能是一个在线版的单词阶梯游戏。单词阶梯游戏,也称为字母阶梯或词链,是一种语言游戏,玩家需要通过改变一个单词中的一个字母来逐渐转换成目标单词,每次变换只能...

    wordladder:JavaScript 代码面试片段

    "wordladder:JavaScript 代码面试片段"是一个面试场景,旨在考察候选人的代码分析、问题解决和重构能力。在这个问题中,面试官通常会提供一段实现字梯游戏的JavaScript代码,字梯游戏是一种逻辑谜题,玩家需要通过...

    WordLadder:构造从原始单词到目标单词的路径,其中中间单词与其相邻单词的字符不同

    WordLadder游戏是一种基于单词的逻辑游戏,最初由著名作家刘易斯·卡罗尔(Lewis Carroll)设计,也被称为“单词阶梯”或“字母梯”。在这个游戏中,玩家需要从一个给定的起始单词出发,通过改变一个字母每次形成一...

    wordLadder422C:EE 422C中的单词阶梯项目的存储库

    "wordLadder422C" 是一个特定的项目名称,它与EE 422C这门课程相关。EE通常代表Electrical Engineering(电子工程),而422C可能是课程编号,这表明这个项目是为电子工程专业学生设计的。"单词阶梯"(Word Ladder)...

    Coding Interview In Java

    5 Word Ladder 27 6 Word Ladder II 29 7 Median of Two Sorted Arrays 33 8 Kth Largest Element in an Array 35 9 Wildcard Matching 37 10 Regular Expression Matching in Java 39 11 Merge Intervals 43 12 ...

    c++数据结构与算法实现

    WordLadder.cpp: Word Ladder Program and Word Changing Utilities SeparateChaining.h: Header file for separate chaining SeparateChaining.cpp: Implementation for separate chaining TestSeparateChaining...

    python-leetcode题解之127-Word-Ladder

    python python_leetcode题解之127_Word_Ladder

    数据结构与算法分析Java语言描述随书源码

    - **WordLadder.java**: 词链问题,涉及图论和搜索算法,如广度优先搜索(BFS),通常用于找到两个单词之间通过改变一个字母形成的新单词的最短路径。 - **堆数据结构** (PairingHeap.java): 堆是一种特殊的树形数据...

    练习 GoGo 编程挑战集锦.zip

    CPU/Mem挑战(@macocha,@mick4711)国际象棋(@kennygrant)弗洛伊德(@ledongthuc)字谜(@heliac2000)年(@nguyengiabk)mergesort(@nguyengiabk)wordladder( @EvenPeng )十进制和( @bediger4000 )构建单词(@...

    LeetCode题解(java语言实现).pdf

    * Word Ladder:该题目要求将一个单词转换成另一个单词,实现方法使用了广度优先搜索算法。 二、树和图 * Median of Two Sorted Arrays Java:该题目要求找到两个排序数组的中位数,实现方法使用了二分查找算法。 ...

    数据结构与算法分析(Java)

    63.java HashFamily.java IntCell.java KdTree.java LeftistHeap.java MaxSumTest.java MemoryCell.java MyArrayList.java MyLinkedList.java ...TestMemoryCell.java Treap.java UnderflowException.java WordLadder.java

    js-leetcode题解之127-word-ladder.js

    javascript js_leetcode题解之127-word-ladder.js

    python-leetcode题解之126-Word-Ladder-II

    python python_leetcode题解之126_Word_Ladder_II

    单词接龙(java代码).docx

    public class WordLadder { public int ladderLength(String beginWord, String endWord, List&lt;String&gt; wordList) { // 将 wordList 转换为 set,方便查询 Set&lt;String&gt; wordSet = new HashSet(wordList); // ...

Global site tag (gtag.js) - Google Analytics