给你一个字符串 s 、一个字符串 t 。返回 s 中涵盖 t 所有字符的最小子串。如果 s 中不存在涵
盖 t 所有字符的子串,则返回空字符串 "" 。
注意:如果 s 中存在这样的子串,我们保证它是唯一的答案。
题解
滑动窗口
代码
class Solution {
public:
string minWindow(string s, string t) {
int slen=s.size(),tlen=t.size();
unordered_map<char,int> cntMap;
unordered_map<char,bool> hasMap;
for (int i=0;i<slen;i++) hasMap[s[i]]=false;
for (int i=0;i<tlen;i++){
cntMap[t[i]]++;
hasMap[t[i]]=true;
}
int sum=0,diff=cntMap.size();
int minLen=slen+1,start=0;
for (int l=0,h=0;l<slen;l++){
if (hasMap[s[l]]){
while (h<slen&&sum!=diff){
if (hasMap[s[h]]){
cntMap[s[h]]--;
if (cntMap[s[h]]==0) sum++;
}
h++;
}
if (sum==diff&&minLen>h-l){
minLen=h-l;
start=l;
}
if (cntMap[s[l]]==0) sum--;
cntMap[s[l]]++;
}
}
if (minLen==slen+1) return "";
return s.substr(start,minLen);
}
};
题目描述给你一个字符串 s 、一个字符串 t 。返回 s 中涵盖 t 所有字符的最小子串。如果 s 中不存在涵盖 t 所有字符的子串,则返回空字符串 "" 。注意:如果 s 中存在这样的子串,我们保证它是唯一的答案。题解滑动窗口代码class Solution {public: string minWindow(string s, string t) { int slen=s.size(),tlen=t.size(); unorder.