g0001_0100.s0076_minimum_window_substring.Solution Maven / Gradle / Ivy
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%)
/**
* 76 - Minimum Window Substring\.
*
* Hard
*
* Given two strings `s` and `t` of lengths `m` and `n` respectively, return _the **minimum window substring** of_ `s` _such that every character in_ `t` _( **including duplicates** ) is included in the window. If there is no such substring__, return the empty string_ `""`_._
*
* The testcases will be generated such that the answer is **unique**.
*
* A **substring** is a contiguous sequence of characters within the string.
*
* **Example 1:**
*
* **Input:** s = "ADOBECODEBANC", t = "ABC"
*
* **Output:** "BANC"
*
* **Explanation:** The minimum window substring "BANC" includes 'A', 'B', and 'C' from string t.
*
* **Example 2:**
*
* **Input:** s = "a", t = "a"
*
* **Output:** "a"
*
* **Explanation:** The entire string s is the minimum window.
*
* **Example 3:**
*
* **Input:** s = "a", t = "aa"
*
* **Output:** ""
*
* **Explanation:** Both 'a's from t must be included in the window. Since the largest window of s only has one 'a', return empty string.
*
* **Constraints:**
*
* * `m == s.length`
* * `n == t.length`
* * 1 <= m, n <= 105
* * `s` and `t` consist of uppercase and lowercase English letters.
*
* **Follow up:** Could you find an algorithm that runs in `O(m + n)` time?
**/
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);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy