Leetcode 648:单词替换

本文介绍了一种基于词根的字符串替换算法,该算法能在给定的词典中找到句子中词汇的最短词根,并进行替换。适用于英语词汇分析和简化场景,如将继承词替换为其构成的词根。

题目描述

在英语中,我们有一个叫做 词根(root)的概念,它可以跟着其他一些词组成另一个较长的单词——我们称这个词为 继承词(successor)。例如,词根an,跟随着单词 other(其他),可以形成新的单词 another(另一个)。

现在,给定一个由许多词根组成的词典和一个句子。你需要将句子中的所有继承词词根替换掉。如果继承词有许多可以形成它的词根,则用最短的词根替换它。

你需要输出替换之后的句子。

示例 1:

输入: dict(词典) = ["cat", "bat", "rat"]
sentence(句子) = "the cattle was rattled by the battery"
输出: "the cat was rat by the bat"

注:

  1. 输入只包含小写字母。
  2. 1 <= 字典单词数 <=1000
  3. 1 <=  句中词语数 <= 1000
  4. 1 <= 词根长度 <= 100
  5. 1 <= 句中词语长度 <= 1000

 

解题思路

class Solution {
public:
    string replaceWords(vector<string>& dict, string sentence) {
        unordered_set<string> st;
        for(int i=0;i<dict.size();i++) st.insert(dict[i]);
        string ans = "";
        string::size_type post,pre;
        pre = 0;
        post = sentence.find_first_of(" ");
        while(pre != string::npos){
            if(post == string::npos) post = sentence.length();
            string tmp = sentence.substr(pre,post-pre);
            string root = "";
            for(int j=0;j<tmp.length();j++){
                root += tmp[j];
                if(st.find(root)!=st.end()) break;
            }
            ans += root+" ";
            if(post == sentence.length()) break;
            pre = post+1;
            post = sentence.find_first_of(" ",pre);
        }
        ans.erase(ans.length()-1);
        return ans;
    }
};
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值