# 1208. 尽可能使字符串相等
# 题目
给你两个长度相同的字符串,s
和 t
。
将 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
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)