力扣--76. 最小覆盖子串

给你一个字符串 s 、一个字符串 t 。返回 s 中涵盖 t 所有字符的最小子串。如果 s 中不存在涵盖 t 所有字符的子串,则返回空字符串 ""

注意:

  • 对于 t 中重复字符,我们寻找的子字符串中该字符数量必须不少于 t 中该字符数量。
  • 如果 s 中存在这样的子串,我们保证它是唯一的答案。

示例 1:

复制代码
输入:s = "ADOBECODEBANC", t = "ABC"
输出:"BANC"
解释:最小覆盖子串 "BANC" 包含来自字符串 t 的 'A'、'B' 和 'C'。

示例 2:

复制代码
输入:s = "a", t = "a"
输出:"a"
解释:整个字符串 s 是最小覆盖子串。

示例 3:

复制代码
输入: s = "a", t = "aa"
输出: ""
解释: t 中两个字符 'a' 均应包含在 s 的子串中,
因此没有符合条件的子字符串,返回空字符串。

提示:

  • m == s.length
  • n == t.length
  • 1 <= m, n <= 105
  • st 由英文字母组成

此题考虑用滑动窗口来做,套用模板就成~

cpp 复制代码
string minWindow(string s, string t) {
        unordered_map<char,int> window,need;//定义哈希表,存放窗口中的字符串和t中每个字符的个数
        for(char c:t) need[c]++;
        int left=0,right=0,val=0,len=INT_MAX,stat=0;
        while(right<s.size()){
            char c=s[right];
            right++;
            // 扩大窗口操作
            if(need.count(c)){//判断right是否在need当中
                window[c]++;//如果在就把窗口中该字符+1
                if(window[c]==need[c]){//判断窗口中的目标字符个数是否和need中的字符个数相等
                    val++;
                }
            }
            while(val==need.size()){
                // 更新窗口最小长度
                if(right-left<len){
                    stat=left;
                    len=right-left;
                }
                // 缩小窗口操作
                char d=s[left];
                left++;
                if(need.count(d)){
                    if(window[d]==need[d]){
                        val--;
                    }
                     window[d]--;
                    
                }
            }
        }
        return len==INT_MAX?"":s.substr(stat,len);
    }

提交通过~

相关推荐
Kaltistss40 分钟前
98.验证二叉搜索树
算法·leetcode·职场和发展
知己如祭44 分钟前
图论基础(DFS、BFS、拓扑排序)
算法
mit6.8241 小时前
[Cyclone] 哈希算法 | SIMD优化哈希计算 | 大数运算 (Int类)
算法·哈希算法
c++bug1 小时前
动态规划VS记忆化搜索(2)
算法·动态规划
哪 吒1 小时前
2025B卷 - 华为OD机试七日集训第5期 - 按算法分类,由易到难,循序渐进,玩转OD(Python/JS/C/C++)
python·算法·华为od·华为od机试·2025b卷
小刘同学3212 小时前
C++11 特性
c++·c11新特性
军训猫猫头2 小时前
1.如何对多个控件进行高效的绑定 C#例子 WPF例子
开发语言·算法·c#·.net
success2 小时前
【爆刷力扣-数组】二分查找 及 衍生题型
算法
真的想上岸啊2 小时前
学习C++、QT---18(C++ 记事本项目的stylesheet)
开发语言·c++·学习