minWindowSubsequence function

String minWindowSubsequence(
  1. String s,
  2. String t
)

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);
}