LeetCode 76. 最小覆盖子串

给定两个字符串 st,长度分别是 mn,返回 s 中的 最短窗口 子串 ,使得该子串包含 t 中的每一个字符(包括重复字符 )。如果没有这样的子串,返回空字符串""

测试用例保证答案唯一。

示例 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 复制代码
class Solution {
    bool is_covered(int cnt_s[],int cnt_t[])
    {
        for(int i='a';i<='z';i++)
        {
            if(cnt_s[i]<cnt_t[i])
            return false;
        }
        for(int i='A';i<='Z';i++)
        {
            if(cnt_s[i]<cnt_t[i])
            return false;
        }
        return true;
    }
public:
    string minWindow(string s, string t) {
        int cnt_s[128]{};
        int cnt_t[128]{};
        for(auto c:t)
        {
            cnt_t[c]++;
        }
        int m=s.size();
        int ansLeft=-1,ansRight=m;
        int left=0;
        for(int right=0;right<m;right++)
        {
            cnt_s[s[right]]++;
            while(is_covered(cnt_s,cnt_t))
            {
                if(right-left<ansRight-ansLeft)
                {
                    ansLeft=left;
                    ansRight=right;
                }
                cnt_s[s[left]]--;
                left++;
            }
        }
        return ansLeft<0?"":s.substr(ansLeft,ansRight-ansLeft+1);
    }
};
相关推荐
为思念酝酿的痛29 分钟前
POSIX信号量
linux·运维·服务器·后端
专业白嫖怪34 分钟前
什么是docker
运维·docker·容器
隔窗听雨眠1 小时前
Nginx网关响应慢排查手记
java·服务器·nginx
人还是要有梦想的2 小时前
linux下用搜狗输入法,中英文切换
linux·运维·服务器
北京智和信通2 小时前
某部队IT基础设施及机房动环统一运维建设实例
运维·网管平台·网管软件·网络管理系统·网络运维平台·网络运维系统
乐维_lwops2 小时前
从 “救火运维” 到 “自动驾驶”:运维智能体到底解决了什么?
运维·人工智能·运维智能体
bush42 小时前
嵌入式linux学习记录二
linux·运维·学习
9分钟带帽2 小时前
linux_通过NFS挂载远程服务器的硬盘
linux·服务器
weixin_468466852 小时前
MoneyPrinterTurbo 短视频自动化生产实战指南
运维·人工智能·自动化·大模型·音视频·moneyprinter
難釋懷3 小时前
Nginx自签名-图形化工具 XCA
运维·nginx