Re: [闲聊] 每日leetcode

楼主: sustainer123 (caster)   2024-05-28 13:21:08
※ 引述《oin1104 (是oin的说)》之铭言:
: You are given two strings s and t of the same length and an integer maxCost.
: You want to change s to t. Changing the ith character of s to ith character of t
: costs |s[i] - t[i]| (i.e., the absolute difference between the ASCII values of
: the characters).
: Return the maximum length of a substring of s that can be changed to be the same
: as the corresponding substring of t with a cost less than or equal to maxCost.
: If there is no substring from s that can be changed to its corresponding substri
: ng from t, return 0.
: 题目:
: 给你两个字串 s跟t 还有maxCost
: 你可以更改每个字母的ascii值
: 但是更改总值不可以超过maxCost
: 问你最长的更改后相同子字串有多长
: 思路:
: 这种区间内求东西的
: 而且需要一直纪录更改区间内的值
: 所以用sliding window 就很方便
: ```cpp
: class Solution {
: public:
: int equalSubstring(string s, string t, int maxCost)
: {
: int res = 0;
: int len = s.size();
: vector<int> paper(len , 0);
: for(int i = 0 ; i < len ; i ++)
: {
: paper[i] = abs(s[i]-t[i]);
: }
: int l = 0;
: int r = 0;
: int cn = 0;
: for(r = 0 ; r < len ; r ++)
: {
: cn += paper[r];
: while(cn > maxCost)
: {
: cn -= paper[l];
: l ++;
: }
: res = max(r-l+1, res);
: }
: return res;
: }
: };
思路:
sliding window 差值<=maxcost right往前并更新结果 反之 left往前
把left的差值加回去
Python Code:
class Solution:
def equalSubstring(self, s: str, t: str, maxCost: int) -> int:
left = 0
right = 0
res = 0
while right < len(s):
d = abs(ord(s[right]) - ord(t[right]))
if d > maxCost:
maxCost += abs(ord(s[left]) - ord(t[left]))
left += 1
else:
right += 1
maxCost -= d
res = max(right - left,res)
return res
作者: Smallsh (Smallsh)   2023-05-28 13:21:00
大师
作者: SecondRun (雨夜琴声)   2023-05-28 13:21:00
大师
作者: DJYOSHITAKA (Evans)   2024-05-28 13:29:00
大白天就在卷
楼主: sustainer123 (caster)   2024-05-28 13:32:00
无业游民 对啊

Links booklink

Contact Us: admin [ a t ] ucptt.com