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 <= k
is inwordList
. Note thatbeginWord
does 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 <= 10
endWord.length == beginWord.length
1 <= wordList.length <= 5000
wordList[i].length == beginWord.length
beginWord
,endWord
, andwordList[i]
consist of lowercase English letters.beginWord != endWord
- All the words in
wordList
are unique .
Hints/Notes
- 2024/12/28
- BFS
- No solution from 0x3F
Solution
Language: C++
1 | class Solution { |