127. Word Ladder
Description
A transformation sequence from word beginWord to word endWord using a dictionary wordList is a sequence of words beginWord -> s1 -> s2 -> … -> sk such that:
- Every adjacent pair of words differs by a single letter.
- Every si for
1 <= i <= kis inwordList. Note thatbeginWorddoes not need to be inwordList. - sk == endWord
Given two words, beginWord and endWord, and a dictionary wordList, return the number of words in the shortest transformation sequence from beginWord to endWord, or 0 if no such sequence exists.
Example 1:
1 | Input: beginWord = "hit", endWord = "cog", wordList = ["hot","dot","dog","lot","log","cog"] |
Example 2:
1 | Input: beginWord = "hit", endWord = "cog", wordList = ["hot","dot","dog","lot","log"] |
Constraints:
1 <= beginWord.length <= 10endWord.length == beginWord.length1 <= wordList.length <= 5000wordList[i].length == beginWord.lengthbeginWord,endWord, andwordList[i]consist of lowercase English letters.beginWord != endWord- All the words in
wordListare unique .
Hints/Notes
- 2024/12/28
- BFS
- No solution from 0x3F
Solution
Language: C++
1 | class Solution { |