g0001_0100.s0076_minimum_window_substring.Solution Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of leetcode-in-java Show documentation
Show all versions of leetcode-in-java Show documentation
Java-based LeetCode algorithm problem solutions, regularly updated
package g0001_0100.s0076_minimum_window_substring;
// #Hard #Top_100_Liked_Questions #Top_Interview_Questions #String #Hash_Table #Sliding_Window
// #Level_2_Day_14_Sliding_Window/Two_Pointer #2022_06_19_Time_3_ms_(98.22%)_Space_44.3_MB_(61.29%)
public class Solution {
public String minWindow(String s, String t) {
int[] map = new int[128];
for (int i = 0; i < t.length(); i++) {
map[t.charAt(i) - 'A']++;
}
int count = t.length();
int begin = 0;
int end = 0;
int d = Integer.MAX_VALUE;
int head = 0;
while (end < s.length()) {
if (map[s.charAt(end++) - 'A']-- > 0) {
count--;
}
while (count == 0) {
if (end - begin < d) {
d = end - begin;
head = begin;
}
if (map[s.charAt(begin++) - 'A']++ == 0) {
count++;
}
}
}
return d == Integer.MAX_VALUE ? "" : s.substring(head, head + d);
}
}