【一天一道LeetCode】#76. Minimum Window Substring
一天一道LeetCode
本系列文章已全部上传至我的github,地址:ZeeCoder‘s Github
欢迎大家关注我的新浪微博,我的新浪微博
欢迎转载,转载请注明出处
(一)题目
Given a string S and a string T, find the minimum window in S which will contain all the characters in T in complexity O(n).
For example,
S = “ADOBECODEBANC”
T = “ABC”Minimum window is “BANC”.
Note:
If there is no such window in S that covers all characters in T, return the empty string “”.If there are multiple such windows, you are guaranteed that there will always be only one unique minimum window in S.
(二)解题
题目大意:给定两个字符串S和T,求S中的包含T中所有字符的最小子串。
博主内心os:hard的题为什么每次都这么难做!
下面分享一下解题思路:
准备工作
遇到这种求子串的题目,不难想到要用到两个指针start和end记录子串在S中的开始和结束序号。
另外,本题还需要用到哈希的思想,故使用两个数组needFind[256]和find[256],前者用来记录我们需要找的字母及其出现次数,后来用来记录当前找到的字母及其出现次数。数组大小为256是因为字符ascii值在0~256之间。
那么,接下来,我们需要判断什么时候确定找到了一个子串包含T中的所有字符呢?
这里我们定义一个整形数count来记录“有效字符数”。那又有问题了,什么是有效字符?
假设T中有1个字符A,当我们找到第一个的时候count++,当我们找到第二个的时候超过了我们需要找的,故为无效字符,count不变。
又回到上一个问题,count等于T的长度的时候,就确定找到了一个子串包含T中的所有字符。
算法过程
做好如上的准备之后,就是整个算法的思想:
用[start,end]来标记窗口的起始位置,end一直向后扩张,并且find[]不停的记录已找到的字符及其出现的次数,count一直记录有效字符数。
当count等于字符串T的长度时,表示找到了符合要求的子串,这时,就需要对begin进行处理了。
- 当S[begin]为不需要找的字符时,需要去除。如S=“CDAB”,T=“AB”,这时CD就需要去除
- 当S[begin]需要找的字符,但超过了需要找的次数。如S=“AAB”,T=”AB”,这时A就需要去除
这样就找到了当前窗口下的最小子串,然后end继续向后扩张,重复如上步骤。
简而言之就是,扩张收缩在扩张在收缩……
具体的算法请看下面代码:
class Solution {
public:
string minWindow(string s, string t) {
int needFind[256] = {0};//记录需要找的字符及其出现次数
int find[256] = {0};//记录找到的字符及其出现次数
int count = 0;//记录有效字符数
int begin=0,end=0;//记录当前窗口的起始位置和结束为止
int minbegin = 0 , minlen = 2147483647;//记录最小窗口及其大小
for(int i = 0 ; i < t.size() ; i++) needFind[t[i]]++;//初始化需要找的字符及其需要出现的次数
for(;end<s.length();end++)
{
if(needFind[s[end]]==0) continue;//如果不是需要找的字符就继续下一个
find[s[end]]++;//找到的需要找的字符,其次数加1
if(find[s[end]]<=needFind[s[end]]) count++;.//如果找到的字符的次数小于或等于需要找的次数,则记为有效字符
if(count==t.length())//找到了包含T中所有字符的子串
{
while(begin<end) {//去除窗口前面的无效字符
if(needFind[s[begin]]==0) begin++;//不需要找的字符去除
else if(find[s[begin]] > needFind[s[begin]])//超过次数的字符去除
{
find[s[begin]]--;//去除后次数减1
begin++;
}
else break;
}
int templen = end-begin+1;//计算当前窗口的长度
if(minlen>templen)
{
minlen = templen;
minbegin = begin;
}
}
}
return minlen == 2147483647 ?"":s.substr(minbegin,minlen);如果没有找到就返回“”,反之返回找到的子串
}
};
【一天一道LeetCode】#76. Minimum Window Substring的更多相关文章
- [LeetCode] 76. Minimum Window Substring 最小窗口子串
Given a string S and a string T, find the minimum window in S which will contain all the characters ...
- [LeetCode] 76. Minimum Window Substring 解题思路
Given a string S and a string T, find the minimum window in S which will contain all the characters ...
- [leetcode]76. Minimum Window Substring最小字符串窗口
Given a string S and a string T, find the minimum window in S which will contain all the characters ...
- Leetcode#76 Minimum Window Substring
原题地址 用两个指针分别记录窗口的左右边界,移动指针时忽略那些出现在S种但是没有出现在T中的字符 1. 扩展窗口.向右移动右指针,当窗口内的字符即将多于T内的字符时,停止右移 2. 收缩窗口.向右调整 ...
- 刷题76. Minimum Window Substring
一.题目说明 题目76. Minimum Window Substring,求字符串S中最小连续字符串,包括字符串T中的所有字符,复杂度要求是O(n).难度是Hard! 二.我的解答 先说我的思路: ...
- 【LeetCode】76. Minimum Window Substring
Minimum Window Substring Given a string S and a string T, find the minimum window in S which will co ...
- 【LeetCode】76. Minimum Window Substring 最小覆盖子串(Python & C++)
作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 滑动窗口 日期 题目地址: https://leet ...
- 76. Minimum Window Substring
题目: Given a string S and a string T, find the minimum window in S which will contain all the charact ...
- [Leetcode][JAVA] Minimum Window Substring
Given a string S and a string T, find the minimum window in S which will contain all the characters ...
随机推荐
- JConsole/JvisualVM 远程连接失败处理
今天在使用JConsole进行远程连接时,发现IP和端口在Windows下是可以远程telnet的,但是,使用JConsole时却无法连接. 我的环境如下: Windows下运行JConsole,准备 ...
- MLDS笔记:浅层结构 vs 深层结构
深度学习出现之前,机器学习方面的开发者通常需要仔细地设计特征.设计算法,且他们在理论上常能够得知这样设计的实际表现如何: 深度学习出现后,开发者常先尝试实验,有时候实验结果常与直觉相矛盾,实验后再找出 ...
- 如何处理JS,css与smarty标签的冲突
smarty的默认标记符是大括号:{}, 假如我们页面上有JS且定义了函数或者对象,或者有CSS定义了样式,就会出现大括号, smary引擎就会把这些大括号当作smarty语法来解释, 很明显,这些C ...
- JAVAEE——BOS物流项目11:在realm中授权、shiro的方法注解权限控制、shiro的标签权限控制、总结shiro的权限控制方式、权限管理
1 学习计划 1.在realm中进行授权 2.使用shiro的方法注解方式权限控制 n 在spring文件中配置开启shiro注解支持 n 在Action方法上使用注解 3.★使用shiro的标签进行 ...
- Android反编译(未混淆的apk)
Android反编译(未混淆的apk) 工具 dex2jar 下载地址:我的CSDN 或者 官网 jd-gui 下载地址:我的CSDN 或者 官网 反编译步骤 1. 将APK解压缩,获取classes ...
- Quartz学习笔记1:Quartz概述
Quartz是开源任务调度框架中的翘楚,它提供了强大的 任务调度机制.Quartz允许开发人员灵活的定义触发器的调度时间表,并可对触发器和任务进行关联映射.此外,Quartz提供了调度运行环境的持久化 ...
- [CSDN_Markdown] 使用LaTeX写矩阵
简介 LaTeX 的公式功能非常强大,一次性讲全不是件容易的事情.将LaTeX 的这些功能分成较小的相互独立的部分来讲,一方面方便大家单独查阅:另一方面,所有[CSDN_Markdown]相关的文章都 ...
- ROSCon 2016视频和幻灯片发布 ROS机器人操作系统重要参考资料
ROSCon 2016视频和幻灯片发布 By Tully Foote on 十月19,2016 7:28 AM 全部PPT下载地址:http://pan.baidu.com/s/1gf2sn2F RO ...
- PLSQL程序编写杂烦数据表信息编写批量排版
--PLSQL程序编写杂烦数据表信息编写批量排版 SELECT 'cra.' || lower(t.column_name) ||',' FROM dba_tab_columns t WHERE t. ...
- android面试手册
1. Android dvm的进程和Linux的进程, 应用程序的进程是否为同一个概念 DVM指dalivk的虚拟机.每一个Android应用程序都在它自己的进程中运行,都拥有一个独立的Dalvik虚 ...