题解 | #最小覆盖子串#

最小覆盖子串

http://www.nowcoder.com/practice/c466d480d20c4c7c9d322d12ca7955ac

来个JAVA版本的,思路都一样

import java.util.*;
public class Solution {
    /**
     * 
     * @param S string字符串 
     * @param T string字符串 
     * @return string字符串
     */
    public String minWindow (String S, String T) {
        // write code here
        HashMap<Character,Integer> need = new HashMap<>();
        HashMap<Character,Integer> window = new HashMap<>();
        for(int i = 0;i < T.length();i++){
            char c = T.charAt(i);
            need.put(c,need.getOrDefault(c,0) + 1);
        }
        int right = 0;
        int left = 0;
        int valid = 0;
        int minlen = Integer.MAX_VALUE;
        int start = 0;
        while(right < S.length()){
            char c = S.charAt(right);
            right++;
            if(need.containsKey(c)){
                window.put(c,window.getOrDefault(c,0) + 1);
                if(need.get(c) == window.get(c)){
                    valid++;
                }
            }
            while(valid == need.size()){
                if(right - left < minlen){
                    start = left;
                    minlen = right - left;
                }
                char d = S.charAt(left);
                left++;
                if(need.containsKey(d)){
                    if(need.get(d) == window.get(d)){
                        valid--;
                    }
                window.put(d,window.getOrDefault(d,0) - 1);
                }
            }
        }
        return minlen == Integer.MAX_VALUE ? "" : S.substring(start,start + minlen);
    }
}

全部评论

相关推荐

3 2 评论
分享
牛客网
牛客企业服务