leetcode 76:最小覆盖子串

2024-09-02 15:32
文章标签 leetcode 覆盖 最小 子串 76

本文主要是介绍leetcode 76:最小覆盖子串,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

       这道题我使用了很笨的方式花了好久解决了,但是时间复杂度太度,只看网上查看源码,不得不说网上的答案基本都是一样的,但是对于基础相对薄弱的我来说这些代码看起来很是费劲,还用要加强C++基础的练习才行。

       思路相对来说不是很难:

       1 首先构架t字符串的hash表,因为字符与ASCII码较好的关系,使用vector数组map来构造hash表,所存的int型表示该字符出现的次数

vector<int> map(128,0);
for(auto c: t)map[c]++;

     2使用counter表示字符串t的个数,begin end表示子字符串的开始下标和结束下标,初始为0  d表示最短子字符串的个数 初始为最大值,head表示最小的子字符串的初始下标,初始为0   使用head和d可以找到子字符串

     3首先,先将所有的t的字符串找到,每找到一个,count--,将当前子字符串的所有的int值减1,第一次找到t中所有的字符后,count=0,所有t中字符对应的hash值都等于0,而s在中不在t中的字符对应的hash值都小于0

     4 当begin下标对应的字符等于0时,表示该字符在t中,往后移动窗口时,当前begin在窗口外,所以此时count++,begin向后移动之后,再次使得count==0,以此循环,直到窗口到达最后,找到最小的窗口

string minWindow(string s, string t) {vector<int> map(128,0);for(auto c: t)map[c]++;int counter=t.size(), begin=0, end=0, d=INT_MAX, head=0;while(end<s.size()){if(map[s[end]]>0){map[s[end]]-=1;end+=1;counter--; //in t}else{map[s[end]]-=1;end+=1;}while(counter==0){ //validif(end-begin<d)d=end-(head=begin);if(map[s[begin]]==0){map[s[begin]]+=1;begin+=1;counter++; //make it invalid}else{map[s[begin]]+=1;begin+=1;}}}return d==INT_MAX? "":s.substr(head, d);
}

网上源码有点儿复杂,看起来很蒙,我将其简单化

这篇关于leetcode 76:最小覆盖子串的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1130353

相关文章

哈希leetcode-1

目录 1前言 2.例题  2.1两数之和 2.2判断是否互为字符重排 2.3存在重复元素1 2.4存在重复元素2 2.5字母异位词分组 1前言 哈希表主要是适合于快速查找某个元素(O(1)) 当我们要频繁的查找某个元素,第一哈希表O(1),第二,二分O(log n) 一般可以分为语言自带的容器哈希和用数组模拟的简易哈希。 最简单的比如数组模拟字符存储,只要开26个c

poj2406(连续重复子串)

题意:判断串s是不是str^n,求str的最大长度。 解题思路:kmp可解,后缀数组的倍增算法超时。next[i]表示在第i位匹配失败后,自动跳转到next[i],所以1到next[n]这个串 等于 n-next[n]+1到n这个串。 代码如下; #include<iostream>#include<algorithm>#include<stdio.h>#include<math.

poj3261(可重复k次的最长子串)

题意:可重复k次的最长子串 解题思路:求所有区间[x,x+k-1]中的最小值的最大值。求sa时间复杂度Nlog(N),求最值时间复杂度N*N,但实际复杂度很低。题目数据也比较水,不然估计过不了。 代码入下: #include<iostream>#include<algorithm>#include<stdio.h>#include<math.h>#include<cstring

spoj705( 求不相同的子串个数)

题意:求串s的不同子串的个数 解题思路:任何子串都是某个后缀的前缀,对n个后缀排序,求某个后缀的前缀的个数,减去height[i](第i个后缀与第i-1 个后缀有相同的height[i]个前缀)。 代码如下: #include<iostream>#include<algorithm>#include<stdio.h>#include<math.h>#include<cstrin

poj 1258 Agri-Net(最小生成树模板代码)

感觉用这题来当模板更适合。 题意就是给你邻接矩阵求最小生成树啦。~ prim代码:效率很高。172k...0ms。 #include<stdio.h>#include<algorithm>using namespace std;const int MaxN = 101;const int INF = 0x3f3f3f3f;int g[MaxN][MaxN];int n

poj 1287 Networking(prim or kruscal最小生成树)

题意给你点与点间距离,求最小生成树。 注意点是,两点之间可能有不同的路,输入的时候选择最小的,和之前有道最短路WA的题目类似。 prim代码: #include<stdio.h>const int MaxN = 51;const int INF = 0x3f3f3f3f;int g[MaxN][MaxN];int P;int prim(){bool vis[MaxN];

poj 2349 Arctic Network uva 10369(prim or kruscal最小生成树)

题目很麻烦,因为不熟悉最小生成树的算法调试了好久。 感觉网上的题目解释都没说得很清楚,不适合新手。自己写一个。 题意:给你点的坐标,然后两点间可以有两种方式来通信:第一种是卫星通信,第二种是无线电通信。 卫星通信:任何两个有卫星频道的点间都可以直接建立连接,与点间的距离无关; 无线电通信:两个点之间的距离不能超过D,无线电收发器的功率越大,D越大,越昂贵。 计算无线电收发器D

poj 1734 (floyd求最小环并打印路径)

题意: 求图中的一个最小环,并打印路径。 解析: ans 保存最小环长度。 一直wa,最后终于找到原因,inf开太大爆掉了。。。 虽然0x3f3f3f3f用memset好用,但是还是有局限性。 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#incl

hdu 1102 uva 10397(最小生成树prim)

hdu 1102: 题意: 给一个邻接矩阵,给一些村庄间已经修的路,问最小生成树。 解析: 把已经修的路的权值改为0,套个prim()。 注意prim 最外层循坏为n-1。 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#include <cstri

poj 2175 最小费用最大流TLE

题意: 一条街上有n个大楼,坐标为xi,yi,bi个人在里面工作。 然后防空洞的坐标为pj,qj,可以容纳cj个人。 从大楼i中的人到防空洞j去避难所需的时间为 abs(xi - pi) + (yi - qi) + 1。 现在设计了一个避难计划,指定从大楼i到防空洞j避难的人数 eij。 判断如果按照原计划进行,所有人避难所用的时间总和是不是最小的。 若是,输出“OPETIMAL",若