LeetCode hoot 100 -- 最小覆盖子串

本题取自LeetCode hoot 100 题号76 最小覆盖子串

一 题目概述

给定两个字符串 st,长度分别是 mn,返回 s 中的 最短窗口子串 ,使得该子串包含 t 中的每一个字符(包括重复字符 )。如果没有这样的子串,返回空字符串""

注:判断是否是覆盖子串时,既需要判断种类是否一致也需要保证某个字符的个数不能少于t中字符的个数

二 思路解析

本题利用双指针来判别最短窗口:

利用右指针扩充窗口大小。记录需要的某个字符出现的次数,如果等于t中该字符的出现次数,nums++(记录窗口中出现所需字符的种类)

当种类相等(即找到了一个子串),利用左指针缩减窗口大小。更新某个字符出现的次数,如果小于t中该字符出现的次数,nums--。图示如下:

三 代码实现

cpp 复制代码
// LeetCode
class Solution {
public:
    string minWindow(string s, string t) {
       int curr[128]={0};// 记录窗口出现所需字符的个数
       int target[128]={0};// 记录所需字符和对应的个数
       int nums=0,t_nums=0;// 窗口出现的所需字符种类,和所需字符种类
       int left=0;// 左指针
       int start=0;// 记录左边界,便于截取数组,否则易超内存
       int min_len=s.size()+1;
        // 记录所需字符种类和对应个数
       for(int i=0;i<t.size();i++){
            target[t[i]]++;
            if(target[t[i]]==1) t_nums++;
       }
        // 遍历所有S中的字符
       for(int right=0;right<s.size();right++){
            // 右指针扩充窗口大小
            if(target[s[right]]!=0){
                curr[s[right]]++;
                if(curr[s[right]]==target[s[right]]) nums++;
            }
            // 当窗口成型,左指针更新,缩小窗口
            while(nums==t_nums){
                // 更新最小窗口        
                if(right-left+1<min_len){
                    min_len=right-left+1;
                    start=left;
                }
                // 缩小窗口
                if(target[s[left]]!=0){
                    curr[s[left]]--;
                    // 注意只有目前的字符个数小于所需字符个数才--,而不是不等于
                    if(curr[s[left]]<target[s[left]]) nums--;
                }
                left++;
            }
       }
        // 判断是否存在这个窗口,输出对应字符串
       return min_len == s.size() + 1 ? "" : s.substr(start, min_len); 
    }
};

以上就是本题的思路和C++的实现了

感谢阅读

相关推荐
8Qi81 小时前
LeetCode 516:最长回文子序列
算法·leetcode·职场和发展·动态规划
youngerwang2 小时前
【从搬运工到协处理器:网卡芯片架构、算法、验证与边缘演进深度剖析】
网络·算法·架构·芯片
KaMeidebaby3 小时前
卡梅德生物技术快报|纯化重组蛋白实操详解
人工智能·python·tcp/ip·算法·机器学习
手写码匠4 小时前
从零实现 Prompt 工程引擎:结构化提示、自动优化与多轮自省体系
人工智能·深度学习·算法·aigc
无限码力4 小时前
阿里算法岗 0530笔试真题 - 多约束条件下的元素匹配统计
算法·阿里笔试真题·阿里机试真题·阿里算法岗笔试
lqqjuly4 小时前
MLA — 多头潜在注意力深度解析
深度学习·神经网络·算法
吴可可1234 小时前
SolidWorks草图转三维DWG技巧
算法
redaijufeng5 小时前
C++雾中风景7:闭包
c++·算法·风景
小欣加油5 小时前
leetcode287寻找重复数
数据结构·c++·算法·leetcode