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

提交通过~

相关推荐
祁_z10 小时前
大模型轻量化:模型格式选型(ONNX/GGUF/TFLite) + 压缩三剑客(量化/剪枝/蒸馏)+ 大模型推理执行流程介绍
算法·机器学习·剪枝·量化·蒸馏·大模型轻量化
绛橘色的日落(。・∀・)ノ11 小时前
机器学习之手写数字识别
算法
流年如夢11 小时前
单链表Ⅲ(LeetCode)
数据结构·算法·leetcode·职场和发展
鉴生Eric11 小时前
FOR算法中的AI智能体具体如何实现频谱感知和动态信道选择?请用技术术语详细说明其决策流程
人工智能·算法
量子炒饭大师11 小时前
【优化算法】双指针算法的「义体化」重构 ——【双指针】双指针算法中的指针是如何定义的?如何使用它进行一些简单的算法?
c++·算法·重构·优化算法·双指针
通信小呆呆11 小时前
ZC序列符号同步:多径信道下的四种经典算法
算法
小辉同志11 小时前
62. 不同路径
c++·力扣·多维动态规划
机器学习之心HML11 小时前
粒子群算法求解速冻食品冷链配送路径优化问题,MATLAB代码
算法·matlab·冷链配送路径优化
fie888911 小时前
基于粒子群优化(PSO)算法的带STATCOM的IEEE 30节点系统最优潮流MATLAB实现
开发语言·算法·matlab
arron889911 小时前
DebugView未打印日志原因
c++