Leetcode力扣题解 - 30.串联所有单词的子串

地址:30. 串联所有单词的子串 - 力扣(LeetCode)

 一.思路

本题关键点是:

1.所有关键词长度一致。

2.匹配的是所有关键词连接起来的

大体思路:

那么我们就可以从字符串头开始,每次只匹配关键词总长度个字符。如果匹配成功,在返回的数组中保存起始位置即可。直到走到(字符串长度-关键词总长)的位置停止,因为此时是能保证匹配字符数目与关键词总数一致的最后位置

字符与关键词匹配:

这里可以使用哈希表的方式来判断字符串与关键词是否匹配。

假设 字符串 = "barfoothefoobarman", 关键词 = ["foo","bar"]。

在第一趟中,需要匹配的是barfoo,此时我们创建一个哈希表。

因为关键词的长度固定。这里都是3,所以把此时的字符串barfoo分成bar、foo两个部分装入哈希表中,每装入一个对应的值加一

我们再将关键词依次与哈希表匹配,每匹配成功一个,对应的哈希表值减一

当关键词遍历完成后,如果哈希表中所有值都为0说明此时的字符串与关键词都匹配上了,否则就是没有匹配上。

二.代码

class Solution {
public:
    
    vector<int> findSubstring(string s, vector<string>& words) {
        vector<int> ret;//返回的数组
        int m = words.size(), n = words[0].size();//确定关键词个数、长度
        for(int i = 0; i + m * n < s.size() + 1; i++)//判断条件是走到最后一个字符串长度能与关键词总长一致
        {
            unordered_map<string, int> umap;//哈希表
            for(int j = 0; j < m; j++)//将字符串拆分装入哈希表
            {
                umap[s.substr(i + j * n, n)]++;
            }
            for(string& word : words)//进行关键词与哈希表匹配
            {
                umap[word]--;
                if(umap[word] == 0) umap.erase(word);
            }
            if(umap.empty()) ret.emplace_back(i);//匹配成功
        }
        return ret;
    }
};

· “一名优秀的程序员,在穿越单行道时也会确认双向的来车情况。”——道格拉斯·林德(Doug Linder)


如有错误,敬请斧正

  • 9
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 5
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

就要 宅在家

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值