【算法】滑动窗口——最小覆盖子串

简介: 【算法】滑动窗口——最小覆盖子串

本节博客是对“最小覆盖子串”题目由暴力求解到滑动窗口的思路解析,有需要借鉴即可。



1.题目

题目链接:LINK

这个题目是困难难度,感觉是一个中等题目的感觉。

首先我肯定想到的是暴力求解的方法,大概就是下面这种思路:

在比较找出的子串是否满足条件时候,可以用有效字符的方法,比如下面代码的count计数。

class Solution {
public:
//暴力求解:
    string minWindow(string s, string t) 
    {
        //定义一个哈希表,用来收集t的有关信息
        string ret = "";
        int hash_t[128] = {0};
        for(int i = 0; i < t.size(); i++)
        {
            hash_t[t[i]]++;
        }
        int minlength = 0;
        for(int left = 0; left < s.size(); left++)
        {
            int hash_s[128] = {0};
            int count = 0;
            for(int right = left; right < s.size(); right++)
            {
                //进哈希表
                hash_s[s[right]]++;
                if(hash_s[s[right]] <= hash_t[s[right]])count++;//有效字符++
                
                //判断
                if(count == t.size() && (minlength==0 || minlength >= right - left + 1))
                {
                    minlength = right - left + 1;//有结果就把这次的长度更新过来,下一次比较的时候用
                    ret = s.substr(left, minlength);
                    break;
                }
            }
        }
        return ret;
    }
};

count有效计数原理:

当我们进哈希数组时候,如果这个字符映射的数组值小于等于hash_t的对应数组,则就是需要的,那么count就++,反之则不是

同理,当我们出字符时候,也是这个道理。

2.滑动窗口解法

但是我们可以发现,left 和 right是可以不用回退一直向前的,这就满足双指针,滑动窗口算法的使用条件

所以,代码可以优化成下面代码:

class Solution {
public:
    string minWindow(string s, string t) 
    {
        //统计t的有关信息
        int hash_t[128] = { 0 };
        int kinds = 0;
        for(auto ch : t)
        {
            if(hash_t[ch]++ == 0)kinds++;
        }
        int start = -1;
        int length = INT_MAX;
        //统计s的有关信息
        int hash_s[128] = { 0 };
        for(int left = 0, right = 0, count = 0; right < s.size(); right++)
        {
            //进窗口
            char in = s[right];
            hash_s[in]++;
            if(hash_s[in] == hash_t[in])count++;
            //判断
            while(count == kinds)
            {
                //更新结果
                if(right - left + 1 < length)
                {
                    length = right - left + 1;
                    start = left;
                }
                //出窗口
                char out = s[left];
                if(hash_s[out] == hash_t[out]) count--;
                hash_s[out]--;
                left++;
            }
        }
        if(start == -1)return "";
        else return s.substr(start, length);
    }
};

注:这个地方的count计数与暴力求解的计数区别是这里用的是字母种类个数。

3.总结

如果有前面“滑动窗口”的题目铺垫其实这道题并不难,需要用到count计数的优化以及滑动窗口的思想。


EOF

相关文章
|
2月前
|
算法
【算法】滑动窗口——最大连续1的个数
【算法】滑动窗口——最大连续1的个数
|
2月前
|
算法
【算法】滑动窗口——找到字符串中所有字母异位词
【算法】滑动窗口——找到字符串中所有字母异位词
|
2月前
|
算法
【算法】滑动窗口——将x减到0的最小操作数
【算法】滑动窗口——将x减到0的最小操作数
|
2月前
|
算法
【算法】滑动窗口——无重复字符的最长子串
【算法】滑动窗口——无重复字符的最长子串
|
2月前
|
算法
【算法】滑动窗口——长度最小的子数组
【算法】滑动窗口——长度最小的子数组
|
2月前
|
算法 容器
【算法】滑动窗口——串联所有单词的子串
【算法】滑动窗口——串联所有单词的子串
|
2月前
|
算法
【算法】滑动窗口——水果成篮
【算法】滑动窗口——水果成篮
|
3月前
|
算法 UED 缓存
高并发架构设计三大利器:缓存、限流和降级问题之滑动窗口算法适用于哪些场景
高并发架构设计三大利器:缓存、限流和降级问题之滑动窗口算法适用于哪些场景
|
17天前
|
机器学习/深度学习 算法 数据安全/隐私保护
基于MSER和HOG特征提取的SVM交通标志检测和识别算法matlab仿真
### 算法简介 1. **算法运行效果图预览**:展示算法效果,完整程序运行后无水印。 2. **算法运行软件版本**:Matlab 2017b。 3. **部分核心程序**:完整版代码包含中文注释及操作步骤视频。 4. **算法理论概述**: - **MSER**:用于检测显著区域,提取图像中稳定区域,适用于光照变化下的交通标志检测。 - **HOG特征提取**:通过计算图像小区域的梯度直方图捕捉局部纹理信息,用于物体检测。 - **SVM**:寻找最大化间隔的超平面以分类样本。 整个算法流程图见下图。
|
1天前
|
存储
基于遗传算法的智能天线最佳阵列因子计算matlab仿真
本课题探讨基于遗传算法优化智能天线阵列因子,以提升无线通信系统性能,包括信号质量、干扰抑制及定位精度。通过MATLAB2022a实现的核心程序,展示了遗传算法在寻找最优阵列因子上的应用,显著改善了天线接收功率。

热门文章

最新文章