当前位置:   article > 正文

Leetcode 每日一题——127. 单词接龙_leetcode 127 c++

leetcode 127 c++

127. 单词接龙

给定两个单词(beginWord 和 endWord)和一个字典,找到从 beginWord 到 endWord 的最短转换序列的长度。转换需遵循如下规则:

每次转换只能改变一个字母。
转换过程中的中间单词必须是字典中的单词。
说明:

  1. 如果不存在这样的转换序列,返回 0。
  2. 所有单词具有相同的长度。
  3. 所有单词只由小写字母组成。
  4. 字典中不存在重复的单词。
  5. 你可以假设 beginWord 和 endWord 是非空的,且二者不相同。
    在这里插入图片描述
    该题目是NLP相关算法中经常遇到的问题,最短路径问题首先想到的是广度优先搜索,那么就需要将字典中的词汇构建到图结构中,构建图的方法参考了官方虚节点的思路,具体C++代码如下:
class Solution {
public:
    unordered_map<string,int> word_id;
    vector<vector<int>> edge;
    int wordNum=0;//新标准下可以初始化
    void addWord(string word)
    {
        if(!word_id.count(word))
        {
            word_id[word]=wordNum++;
            edge.emplace_back();//在edge中添加一个vector<int>占位
        }
    }
    void addEdge(string word)
    {
        addWord(word);
        int idx1=word_id[word];
        for(auto& ch : word)
        {
            char tmp=ch;
            ch='*';
            addWord(word);
            int idx2=word_id[word];
            edge[idx1].push_back(idx2);
            edge[idx2].push_back(idx1);
            ch=tmp;
        }
    }
    int ladderLength(string beginWord, string endWord, vector<string>& wordList) {
        for(auto& word : wordList) addEdge(word);
        addEdge(beginWord);
        if(!word_id.count(endWord)) return 0;

        int beginId=word_id[beginWord];
        int endId=word_id[endWord];
        vector<int> dis(wordNum,INT_MAX);//储存距离
        dis[beginId]=0;

        queue<int> my_queue;
        my_queue.push(beginId);
        while(!my_queue.empty())
        {
            int currentId=my_queue.front();
            my_queue.pop();
            if(currentId==endId)
            {
                return dis[currentId]/2+1;
            }
            for(auto& id : edge[currentId])
            {
                if(dis[id]==INT_MAX)
                {
                    dis[id]=dis[currentId]+1;
                    my_queue.push(id);
                }
            }
        }
        return 0;
    }
};
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52
  • 53
  • 54
  • 55
  • 56
  • 57
  • 58
  • 59
  • 60

运行效果:
在这里插入图片描述

来源:力扣(LeetCode链接:https://leetcode-cn.com/problems/word-ladder

声明:本文内容由网友自发贡献,转载请注明出处:【wpsshop博客】
推荐阅读
相关标签
  

闽ICP备14008679号