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;
    }
}
posted @ 2020-10-28 16:06  yourText  阅读(48)  评论(0编辑  收藏  举报