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);
    }
};
相关推荐
Mortalbreeze1 小时前
深度理解进程----进程状态
linux·运维·服务器
艾莉丝努力练剑1 小时前
【Linux网络】Linux 网络编程入门:TCP Socket 编程(下)
linux·运维·服务器·网络·c++·tcp/ip
yuezhilangniao1 小时前
Ansible基础 ansible入门 针对不同python3版本 - 含 Terraform 入门联动
运维·自动化·ansible
宵时待雨1 小时前
linux笔记归纳4:进程概念
linux·运维·服务器·c++·笔记
一勺菠萝丶1 小时前
如何在 Linux 服务器上使用 Speedtest 官方 CLI 测试带宽(小白教程)
java·服务器·前端
原来是猿1 小时前
TCP Echo Server 深度解析:从单进程到线程池的演进之路(中)
linux·服务器·数据库
leoZ2312 小时前
Linux 环境常用服务一键部署文档(Docker 版)
运维·docker·容器
落魄实习生2 小时前
Jenkins安装及使用
运维·jenkins
QuestLab2 小时前
让AI真正“看见“界面:纯视觉GUI自动化编排器开源了
运维·人工智能·自动化