# 1208. 尽可能使字符串相等

# 题目

给你两个长度相同的字符串,st

s  中的第  i  个字符变到  t  中的第 i 个字符需要  |s[i] - t[i]|  的开销(开销可能为 0),也就是两个字符的 ASCII 码值的差的绝对值。

用于变更字符串的最大预算是  maxCost。在转化字符串时,总开销应当小于等于该预算,这也意味着字符串的转化可能是不完全的。

如果你可以将 s 的子字符串转化为它在 t 中对应的子字符串,则返回可以转化的最大长度。

如果 s 中没有子字符串可以转化成 t 中对应的子字符串,则返回 0。

输入:s = "abcd", t = "cdef", cost = 3

输出:1

解释:s 中的任一字符要想变成 t 中对应的字符,其开销都是 2。因此,最大长度为 1。

# 题解

# 双指针

/**
 * @param {string} s
 * @param {string} t
 * @param {number} maxCost
 * @return {number}
 */
var equalSubstring = function(s, t, maxCost) {
  // 缓存差值
  const diff = new Array(s.length).fill(0);
  for (let i = 0; i < s.length; ++i) {
    diff[i] = Math.abs(s[i].charCodeAt() - t[i].charCodeAt());
  }

  let cost = 0;
  let res = 0;
  let i = (j = 0);
  while (j < s.length) {
    // 更新 cost
    cost += diff[j];

    // 如果 cost 不满足
    while (cost > maxCost) {
      // 更新 cost 左指针向后移动
      cost -= diff[i];
      i++;
    }

    // 更新 res
    res = Math.max(res, j - i + 1);
    // 右指针向后移动
    j++;
  }
  return res;
};
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34

时间复杂度:O(n) 空间复杂度:O(n)