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

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

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



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

相关文章
|
4月前
|
算法
【算法】滑动窗口——最大连续1的个数
【算法】滑动窗口——最大连续1的个数
|
4月前
|
算法
【算法】滑动窗口——找到字符串中所有字母异位词
【算法】滑动窗口——找到字符串中所有字母异位词
|
4月前
|
算法
【算法】滑动窗口——将x减到0的最小操作数
【算法】滑动窗口——将x减到0的最小操作数
|
4月前
|
算法
【算法】滑动窗口——无重复字符的最长子串
【算法】滑动窗口——无重复字符的最长子串
|
4月前
|
算法
【算法】滑动窗口——长度最小的子数组
【算法】滑动窗口——长度最小的子数组
|
4月前
|
算法 容器
【算法】滑动窗口——串联所有单词的子串
【算法】滑动窗口——串联所有单词的子串
|
4月前
|
算法
【算法】滑动窗口——水果成篮
【算法】滑动窗口——水果成篮
|
5月前
|
算法 UED 缓存
高并发架构设计三大利器:缓存、限流和降级问题之滑动窗口算法适用于哪些场景
高并发架构设计三大利器:缓存、限流和降级问题之滑动窗口算法适用于哪些场景
|
16天前
|
算法
基于WOA算法的SVDD参数寻优matlab仿真
该程序利用鲸鱼优化算法(WOA)对支持向量数据描述(SVDD)模型的参数进行优化,以提高数据分类的准确性。通过MATLAB2022A实现,展示了不同信噪比(SNR)下模型的分类误差。WOA通过模拟鲸鱼捕食行为,动态调整SVDD参数,如惩罚因子C和核函数参数γ,以寻找最优参数组合,增强模型的鲁棒性和泛化能力。
|
2天前
|
供应链 算法 调度
排队算法的matlab仿真,带GUI界面
该程序使用MATLAB 2022A版本实现排队算法的仿真,并带有GUI界面。程序支持单队列单服务台、单队列多服务台和多队列多服务台三种排队方式。核心函数`func_mms2`通过模拟到达时间和服务时间,计算阻塞率和利用率。排队论研究系统中顾客和服务台的交互行为,广泛应用于通信网络、生产调度和服务行业等领域,旨在优化系统性能,减少等待时间,提高资源利用率。
下一篇
DataWorks