Leetcode—76. 最小覆盖子串【困难】

2024每日刷题(167)

Leetcode---76. 最小覆盖子串

C++实现代码

cpp 复制代码
class Solution {
public:
    string minWindow(string s, string t) {
        int bestL = -1;
        int l = 0, r = 0;
        vector<int> cnt(128);
        for(const char c: t) {
            cnt[c]++;
        }
        int require = t.length();

        int minLen = s.length() + 1;
        for(; r < s.length(); r++) {
            if(--cnt[s[r]] >= 0) {
                --require;
            }
            while(require == 0) {
                if(r - l + 1 < minLen) {
                    bestL = l;
                    minLen = r - l + 1;
                }
                if(++cnt[s[l++]] > 0) {
                    ++require;
                }
            }
        }
        return bestL == -1 ? "": s.substr(bestL, minLen);
    }
};

运行结果

之后我会持续更新,如果喜欢我的文章,请记得一键三连哦,点赞关注收藏,你的每一个赞每一份关注每一次收藏都将是我前进路上的无限动力 !!!↖(▔▽▔)↗感谢支持!

相关推荐
刺客xs2 小时前
c++多线程 线程池的实现
开发语言·c++
芯有所享2 小时前
【芯片设计中的内存管理单元(MMU):虚拟与物理世界的“地址翻译官”】
经验分享
福楠2 小时前
从C到C++ | 内存管理
c语言·c++
youngee112 小时前
hot100-53搜索旋转排序数组
数据结构·算法·leetcode
.简.简.单.单.2 小时前
Design Patterns In Modern C++ 中文版翻译 第十一章 享元模式
c++·设计模式·享元模式
烟雨梵兮2 小时前
-刷题小结19
算法
BestOrNothing_20152 小时前
C++ 智能指针深入:四种智能指针所有权模型、原理与常见陷阱全景解析
c++·内存管理·智能指针·raii·内存销毁
美洽技术2 小时前
AI客服vs人工客服:80%成本降低的完整对比分析
经验分享
十二测试录3 小时前
Android和iOS测试区别
android·经验分享·ios·职场发展·ab测试
兵哥工控3 小时前
mfc高精度定时器精简版实例
c++·mfc