[CareerCup] 18.10 Word Transform 单词转换

简介:

18.10 Given two words of equal length that are in a dictionary, write a method to transform one word into another word by changing only one letter at a time. The new word you get in each step must be in the dictionary.

这道题让我们将一个单词转换成另一个单词,每次只能改变一个字母,让我们输出中间转换过程的单词。LeetCode上有类似的题目One Edit DistanceEdit Distance。我们的方法是写一个get_one_edit_words()函数,来返回某一个单词变动一个字母的所有可能情况,然后我们在transform函数中先将开始的单词存入一个队列queue中,还需要一个set来记录所有访问过的单词,还需要哈希表来建立当前单词和变换一步后的单词之间的映射,然后开始类似BFS的遍历,对于每一个单词,遍历get_one_edit_words()函数返回的结果,如果变换后的单词就是目标单词,则我们完成了变换,根据backtrack将整个路径上的单词存入结果中,如果变换单词不是目标单词,但是在字典中,如果没有在字典中,则我们将其排入queue,并加入visited,和建立哈希表的映射,继续遍历,参见代码如下:

set<string> get_one_edit_words(string word) {
    set<string> res;
    for (int i = 0; i < word.size(); ++i) {
        string t = word;
        for (char c = 'a'; c <= 'z'; ++c) {
            if (c != word[i]) {
                t[i] = c;
                res.insert(t);
            }
        }
    }
    return res;
}

vector<string> transform(string start, string end, set<string> dict) {
    queue<string> q;
    set<string> visited;
    unordered_map<string, string> backtrack;
    q.push(start);
    visited.insert(start);
    while (!q.empty()) {
        string w = q.front(); q.pop();
        for (string v : get_one_edit_words(w)) {
            if (v == end) {
                vector<string> res{v};
                while (!w.empty()) {
                    res.insert(res.begin(), w);
                    w = backtrack[w];
                }
                return res;
            }
            if (dict.count(v)) {
                if (!visited.count(v)) {
                    q.push(v);
                    visited.insert(v);
                    backtrack[v] = w;
                }
            }
        }
    }
    return {};
}

本文转自博客园Grandyang的博客,原文链接:单词转换[CareerCup] 18.10 Word Transform ,如需转载请自行联系原博主。

相关文章
|
4月前
|
机器学习/深度学习 自然语言处理 Python
|
7月前
|
Java
java字符串分割split你用对了吗
java字符串分割split你用对了吗
【Word】Word公式导出PDF后出现井号括号#()错误
【Word】Word公式导出PDF后出现井号括号#()错误
227 0
word长公式不换行显示的方法
word长公式不换行显示的方法
【Word】docx转doc后公式转换为图片不清晰/模糊
【Word】docx转doc后公式转换为图片不清晰/模糊
444 0
|
机器学习/深度学习 自然语言处理 运维
Word2Vec:一种基于预测的方法
Word2Vec:一种基于预测的方法
308 0
|
Windows
如何将 Tex 转化为 Word 文件
如何将 Tex 转化为 Word 文件
672 0
|
图形学
【Transform3D】转换详解(看完就会)
【Transform3D】转换详解(看完就会)
88823 1
【Transform3D】转换详解(看完就会)
python ljust()、center() 、rjust() 字符串填充左中右对齐
python ljust()、center() 、rjust() 字符串填充左中右对齐
|
自然语言处理 TensorFlow 算法框架/工具
Word2Vec之Skip-Gram与CBOW模型原理
word2vec是一个开源的nlp工具,它可以将所有的词向量化。至于什么是词向量,最开始是我们熟悉的one-hot编码,但是这种表示方法孤立了每个词,不能表示词之间的关系,当然也有维度过大的原因。
1742 0