本文主要是介绍LeetCode 76 最小覆盖子串(尺取法),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
题目链接:最小覆盖子串
给定一个字符串 S 和一个字符串 T,请在 S 中找出包含 T 所有字母的最小子串。
示例:
输入: S = "ADOBECODEBANC", T = "ABC"
输出: "BANC"
说明:
- 如果 S 中不存这样的子串,则返回空字符串
""
。 - 如果 S 中存在这样的子串,我们保证它是唯一的答案。
思路
(滑动窗口) O ( n ) O(n) O(n)
首先用哈希表统计出 T T T 中所有字符出现的次数。
然后我们用两个指针 i , j ( i ≥ j ) i, j(i \ge j) i,j(i≥j)来扫描整个字符串,同时用一个哈希表统计 i , j i, j i,j 之间每种字符出现的次数,每次遍历需要的操作如下:
- 加入 s [ i ] s[i] s[i],同时更新哈希表;
- 检查 s [ j ] s[j] s[j] 是否多余,如果是,则移除 s [ j ] s[j] s[j];
- 检查当前窗口是否已经满足 T T T 中所有字符,如果是,则更新答案;
时间复杂度分析:两个指针都严格递增,最多移动 n n n 次,所以总时间复杂度是 O ( n ) O(n) O(n)。
思路
class Solution
{public://s中最短的一段,包含t中的所有字符string minWindow(string s, string t){string res;unordered_map<char, int> S, T;int total = t.size();for (auto &c : t) //t串中字母的种类{T[c]++;if (T[c] > 1)total--;}int slen = s.size(), cnt = 0; //当前窗口中所有字符for (int i = 0, j = 0; i < slen; i++){S[s[i]]++; //更新哈希表if (S[s[i]] == T[s[i]])cnt++;while (j <= i && S[s[j]] > T[s[j]]){S[s[j]]--;j++;}if (cnt >= total && (res.empty() || i - j + 1 < res.size()))res = s.substr(j, i - j + 1);}return res;}
};
这篇关于LeetCode 76 最小覆盖子串(尺取法)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!