最小覆盖子串

class Solution {

public:

unordered_map<char, int> mp1;

unordered_map<char, int> mp2;

bool check() {

for (auto& c : mp1) {

if (c.second > mp2[c.first])

return false;

}

return true;

}

string minWindow(string s, string t) {

int n = s.size(), m = t.size();

int res = INT_MAX;

int l = 0, r = 0;

for (auto& e : t)

mp1[e]++;

int start = -1;

while (r < n) {

if (mp1.find(s[r]) != mp1.end())

mp2[s[r]]++;

while (check() && l <= r) {

if (r - l + 1 < res) {

start = l;

res = r - l + 1;

}

if (mp1.find(s[l]) != mp1.end())

mp2[s[l]]--;

++l;

}

++r;

}

return start == -1 ? "" : s.substr(start, res);

}

};

相关推荐
m0_629494733 小时前
LeetCode 热题 100-----26.环形链表 II
数据结构·算法·leetcode·链表
壹号用户3 小时前
用队列实现栈
数据结构·算法
做人求其滴3 小时前
面试经典 150 题 380 274
c++·算法·面试·职场和发展·力扣
daad7773 小时前
记一组无人机IMU传感器数据
算法
计算机安禾3 小时前
【c++面向对象编程】第42篇:模板特化与偏特化:为特定类型定制实现
开发语言·c++·算法
小O的算法实验室4 小时前
2026年KBS,流形感知强化学习差分进化算法+不规则3D无人机路径规划,深度解析+性能实测
算法·智能算法·智能算法改进
玖釉-4 小时前
C++ 中的循环语句详解:while、do...while、for、嵌套循环与循环控制
开发语言·c++·算法
不做无法实现的梦~4 小时前
运动控制系统复习一览-----常考题目总结版本
算法
小短腿的代码世界4 小时前
信号路由风暴:Qt算法交易系统的高频信号分发架构
qt·算法·架构