力扣--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);
    }

提交通过~

相关推荐
BestOrNothing_20157 小时前
C++零基础到工程实战(4.3.3):vector数组访问与遍历
c++·迭代器·stl·vector·动态数组
charlie1145141917 小时前
通用GUI编程技术——图形渲染实战(三十三)——Direct2D与Win32/GDI互操作:渐进迁移实战
c++·图形渲染·gui·win32
文祐7 小时前
C++类之虚函数表及其内存布局(一个子类继承一个父类)
开发语言·c++
白羊by8 小时前
YOLOv1~v11 全版本核心演进总览
深度学习·算法·yolo
墨尘笔尖9 小时前
最大最小值降采样算法的优化
c++·算法
YIN_尹11 小时前
【Linux系统编程】进程地址空间
linux·c++
EverestVIP11 小时前
C++中空类通常大小为1的原理
c++
white-persist11 小时前
【vulhub shiro 漏洞复现】vulhub shiro CVE-2016-4437 Shiro反序列化漏洞复现详细分析解释
运维·服务器·网络·python·算法·安全·web安全
网域小星球11 小时前
C++ 从 0 入门(六)|C++ 面试必知:运算符重载、异常处理、动态内存进阶(终极补充)
开发语言·c++·面试
晚会者荣11 小时前
红黑树的插入(有图)
c++