算法练习:76. 最小覆盖子串

题目链接:76. 最小覆盖子串

算法实现,利用双指针,滑动窗口进行解决,

利用两个哈希表进行解决,讲字符串t全部放入一个哈希表中,

然后利用滑动窗口对字符串s进行插入删除操作,

利用一个变量count来记录有效字符

直接看代码注释:

cpp 复制代码
class Solution {
public:
    string minWindow(string s, string t) {
        map<char, int> h1;
        for (auto e : t) h1[e]++;

        map<char, int> h2;
        int retleft = 0;
        int ret = INT_MAX;
        for (int left = 0, right = 0, count = 0; right < s.size(); right++)
        {
            //如果有效字符数和t.size()不相同,就一直进窗口,直到相同
            h2[s[right]]++;
            if (h2[s[right]] <= h1[s[right]]) count++;
            //判断,如果有效字符数和t.size()相同,就进循环判断
            while (count == t.size())
            {
                //如果此时位置处在有效字符上,就直接进行判断范围是否为较小范围
                //因为此时有效字符相同,且left位置刚好是有效字符,那么此时[left,right]一定有效
                if (h1.count(s[left]))
                {
                    if (right - left + 1 < ret)
                    {
                        //记录最小范围 
                        retleft = left;
                        ret = min(ret, right - left + 1);
                    }
                }
                //移动left,缩小区间 ,继续寻找更小范围
                if (h2[s[left]] <= h1[s[left]]) count--;
                h2[s[left]]--;
                left++;
            }
        }
        if(ret == INT_MAX) return "";//如果此时ret == INT_MAX,那么此时一定没找到,返回空
        return s.substr(retleft,ret);//直接利用substr获取出最小范围的字符串
    }
};
相关推荐
汉克老师8 分钟前
GESP2024年6月认证C++二级( 第一部分选择题(9-15))
c++·循环结构·分支结构·gesp二级·gesp2级·求余数
追随者永远是胜利者1 小时前
(LeetCode-Hot100)53. 最大子数组和
java·算法·leetcode·职场和发展·go
生成论实验室1 小时前
即事经:一种基于生成论的宇宙、生命与文明新范式
人工智能·科技·神经网络·算法·信息与通信
王老师青少年编程1 小时前
csp信奥赛c++高频考点假期集训(分模块进阶)
数据结构·c++·算法·csp·高频考点·信奥赛·集训
王老师青少年编程2 小时前
2020年信奥赛C++提高组csp-s初赛真题及答案解析(选择题1-5)
c++·题解·真题·初赛·信奥赛·csp-s·提高组
癫狂的兔子3 小时前
【Python】【机器学习】K-MEANS算法
算法·机器学习·kmeans
Bear on Toilet3 小时前
递归_二叉树_50 . 从前序与中序遍历序列构造二叉树
数据结构·算法·leetcode·深度优先·递归
plus4s3 小时前
2月18日(82-84题)
c++·算法·动态规划
wangluoqi4 小时前
c++ 树上问题 小总结
开发语言·c++
艾醒4 小时前
打破信息差——2026年2月19日AI热点新闻速览
算法