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

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

目录

  • 1.题目
  • 2.滑动窗口解法
  • 3.总结

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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/696768.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

13届蓝桥杯 最大值_c++

题目描述 手工课上老师拿出 N 张长方形彩纸&#xff0c;且每张彩纸上都画着 W*H 的网格&#xff08;网格铺满整张彩纸&#xff09;。现在老师将 N 张彩纸裁剪出 K 张大小相同的正方形&#xff0c;并且要使裁剪出的正方形的边长最大&#xff08;裁剪的正方形边长必须为整数&…

Lesson5--二叉树(超详细版)

【本节目标】 1. 树概念及结构 2. 二叉树概念及结构 3. 二叉树顺序结构及实现 4. 二叉树链式结构及实现 1.树概念及结构 1.1树的概念 树是一种 非线性&#xff08;线性结构就是顺序表链表&#xff09; 的数据结构&#xff0c;它是由 n &#xff08; n>0 &#xff09;个…

粒子群算法(Particle Swarm Optimization)

注意&#xff1a;本文引用自专业人工智能社区Venus AI 更多AI知识请参考原站 &#xff08;[www.aideeplearning.cn]&#xff09; 算法背景 粒子群优化算法&#xff08;Particle Swarm Optimization&#xff0c;PSO&#xff09;的灵感来源于鸟群或鱼群的觅食行为。想象一下&a…

2.三极管

2.习题 3.知识补充

微信小程序毕业设计-基于Java后端的微信小程序源码150套(附源码+数据库+演示视频+LW)

大家好&#xff01;我是程序猿老A&#xff0c;感谢您阅读本文&#xff0c;欢迎一键三连哦。 &#x1f9e1;今天给大家分享150的微信小程序毕业设计&#xff0c;后台用Java开发&#xff0c;这些项目都经过精心挑选&#xff0c;涵盖了不同的实战主题和用例&#xff0c;可做毕业设…

【vue2项目经验总结:部署到服务器之后出现所有数据渲染失败的问题】

原因是因为在没部署到服务器之前前端为了解决跨域问题使用了代理&#xff0c;但是在项目部署到服务器之后&#xff0c;前端通常不再需要使用代理&#xff0c;因为代理的作用是在开发过程中帮助前端应用程序与后端服务进行通信&#xff0c;解决跨域访问等问题。在开发阶段&#…

数据结构与算法-排序算法1-冒泡排序

本文先介绍排序算法&#xff0c;然后具体写冒泡排序。 目录 1.排序算法简介 2.常见的排序算法分类如下图&#xff1a; 3.冒泡排序&#xff1a; 1.介绍&#xff1a; 2.动态图解 3.举例 4.小结冒泡排序规则 5.冒泡排序代码 6.优化 7.优化后时间 代码&#xff1a; 运…

初识C语言——第十九天

for循环 1.简单概述 2.执行流程 3.建议事项&#xff1a;

ssm+vue的公务用车管理智慧云服务监管平台查询统计(有报告)。Javaee项目,ssm vue前后端分离项目

演示视频&#xff1a; ssmvue的公务用车管理智慧云服务监管平台查询统计&#xff08;有报告&#xff09;。Javaee项目&#xff0c;ssm vue前后端分离项目 项目介绍&#xff1a; 采用M&#xff08;model&#xff09;V&#xff08;view&#xff09;C&#xff08;controller&…

Python运维之协程

目录 一、定义协程 二、并发 三、异步请求 协程是一种轻量级的线程&#xff0c;它通过保存和恢复寄存器上下文和栈来实现调度切换&#xff0c;从而保留函数执行的状态。 这种机制使得协程在处理I/O密集型任务时效率较高&#xff0c;因为它们可以在I/O操作期间让出CPU&#…

nacos在没有指定数据源的情况下默认使用什么数据库?

在没有特别指定数据源的情况下&#xff0c;Nacos 默认使用内嵌的数据库 Derby 来存储其数据。Derby 是一个轻量级的、基于 Java 的数据库管理系统&#xff0c;适合于开发和测试环境&#xff0c;因为它简单易部署且无需额外的数据库服务器。然而&#xff0c;对于生产环境&#x…

祝贺嫦娥六号发射成功,思迈特再为航天项目提供数据支持和保障

近日&#xff0c;嫦娥六号由长征五号遥八运载火箭在中国文昌航天发射场发射成功。 据悉&#xff0c;嫦娥六号是中国探月工程的第六个探测器&#xff0c;其主要任务是前往月球背面的南极-艾特肯盆地进行科学探测和样品采集。 嫦娥六号任务不仅是技术上的挑战&#xff0c;也是科学…