minWindowSubsequence function
Minimum Window Subsequence: Returns the minimum window in s containing t as a subsequence.
Implementation
String minWindowSubsequence(String s, String t) {
int m = s.length, n = t.length;
int minLen = m + 1, start = -1;
for (int i = 0, j = 0; i < m; i++) {
if (s[i] == t[j]) {
j++;
if (j == n) {
int end = i + 1;
j--;
int k = i;
while (j >= 0) {
if (s[k] == t[j]) j--;
k--;
}
k++;
if (end - k < minLen) {
minLen = end - k;
start = k;
}
j = 0;
}
}
}
return start == -1 ? '' : s.substring(start, start + minLen);
}