给定两个字符串
s和t,长度分别是m和n,返回 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.lengthn == t.length1 <= m, n <= 105s和t由英文字母组成
cppclass 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); } };
LeetCode 76. 最小覆盖子串
Liangwei Lin2026-05-10 14:07
相关推荐
Mortalbreeze1 小时前
深度理解进程----进程状态艾莉丝努力练剑1 小时前
【Linux网络】Linux 网络编程入门:TCP Socket 编程(下)yuezhilangniao1 小时前
Ansible基础 ansible入门 针对不同python3版本 - 含 Terraform 入门联动宵时待雨1 小时前
linux笔记归纳4:进程概念一勺菠萝丶1 小时前
如何在 Linux 服务器上使用 Speedtest 官方 CLI 测试带宽(小白教程)原来是猿1 小时前
TCP Echo Server 深度解析:从单进程到线程池的演进之路(中)leoZ2312 小时前
Linux 环境常用服务一键部署文档(Docker 版)落魄实习生2 小时前
Jenkins安装及使用QuestLab2 小时前
让AI真正“看见“界面:纯视觉GUI自动化编排器开源了