给定两个字符串
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
相关推荐
为思念酝酿的痛29 分钟前
POSIX信号量专业白嫖怪34 分钟前
什么是docker隔窗听雨眠1 小时前
Nginx网关响应慢排查手记人还是要有梦想的2 小时前
linux下用搜狗输入法,中英文切换北京智和信通2 小时前
某部队IT基础设施及机房动环统一运维建设实例乐维_lwops2 小时前
从 “救火运维” 到 “自动驾驶”:运维智能体到底解决了什么?bush42 小时前
嵌入式linux学习记录二9分钟带帽2 小时前
linux_通过NFS挂载远程服务器的硬盘weixin_468466852 小时前
MoneyPrinterTurbo 短视频自动化生产实战指南難釋懷3 小时前
Nginx自签名-图形化工具 XCA