Skip to content

Latest commit

 

History

History
55 lines (46 loc) · 1.67 KB

127. Word Ladder.md

File metadata and controls

55 lines (46 loc) · 1.67 KB
  1. Word Ladder.md 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 transformed word must exist in the word list. Note:

Return 0 if there is no such transformation sequence. All words have the same length. All words contain only lowercase alphabetic characters. You may assume no duplicates in the word list. You may assume beginWord and endWord are non-empty and are not the same. Example 1:

Input: beginWord = "hit", endWord = "cog", wordList = ["hot","dot","dog","lot","log","cog"]

Output: 5

Explanation: As one shortest transformation is "hit" -> "hot" -> "dot" -> "dog" -> "cog", return its length 5. Example 2:

Input: beginWord = "hit" endWord = "cog" wordList = ["hot","dot","dog","lot","log"]

Output: 0

Explanation: The endWord "cog" is not in wordList, therefore no possible transformation.

#use set to find step word
class Solution: #O(wordlen*26*n)
    def ladderLength(self, beginWord: str, endWord: str, wordList: List[str]) -> int:
        wSet = set(wordList)
        vSet = set([beginWord])
        #bfs
        dq = collections.deque()
        dq.append((beginWord, 1))
        while dq:
            cur, count = dq.popleft()
            if cur == endWord:
                return count
            for i in range(len(cur)):
                for cha in 'qwertyuiopasdfghjklzxcvbnm':
                    nxt = cur[:i] + cha + cur[i+1:]
                    if nxt in wSet and nxt not in vSet:
                        vSet.add(nxt)
                        dq.append((nxt, count+1))
                    
        return 0