LeetCode076——最小覆盖子串
给你一个字符串 S、一个字符串 T,请在字符串 S 里面找出:包含 T 所有字母的最小子串。
示例:
输入: S = "ADOBECODEBANC", T = "ABC"
输出: "BANC"
说明:
如果 S 中不存这样的子串,则返回空字符串 ""。
如果 S 中存在这样的子串,我们保证它是唯一的答案。
public class Solution {
public String minWindow(String s, String t) {
HashMap<Character, Integer> hashMap = new HashMap<>();
for (int i = 0; i < t.length(); i++) {
if(hashMap.containsKey(t.charAt(i))){
hashMap.put(t.charAt(i), hashMap.get(t.charAt(i)) + 1);
}else{
hashMap.put(t.charAt(i), 1);
}
}
int left = 0;
int right = -1;
int count = 0; //[left, right] contains count characters in t
String result = "";
int len = s.length() + 1;
while(left < s.length()){
if(right + 1 < s.length() && count < t.length()){
right++;
if(hashMap.containsKey(s.charAt(right))){
if(hashMap.get(s.charAt(right)) > 0){
count++;
}
hashMap.put(s.charAt(right), hashMap.get(s.charAt(right)) - 1);
}
}else{
if(hashMap.containsKey(s.charAt(left))){
if(hashMap.get(s.charAt(left)) == 0) {
count--;
}
hashMap.put(s.charAt(left), hashMap.get(s.charAt(left)) + 1);
}
left++;
}
if(count == t.length()){
if(right - left + 1 < len){
len = right - left + 1;
result = s.substring(left, right + 1);
}
}
}
return result;
}
}