2021-02-02:力扣424. 替换后的最长重复字符。如何用代码实现?

举报
福大大架构师每日一题 发表于 2021/02/02 21:14:34 2021/02/02
【摘要】 福哥答案2021-02-02:双指针我们可以枚举字符串中的每一个位置作为右端点,然后找到其最远的左端点的位置,满足该区间内除了出现次数最多的那一类字符之外,剩余的字符(即非最长重复字符)数量不超过 kk 个。这样我们可以想到使用双指针维护这些区间,每次右指针右移,如果区间仍然满足条件,那么左指针不移动,否则左指针至多右移一格,保证区间长度不减小。虽然这样的操作会导致部分区间不符合条件,即该区...

福哥答案2021-02-02:

双指针
我们可以枚举字符串中的每一个位置作为右端点,然后找到其最远的左端点的位置,满足该区间内除了出现次数最多的那一类字符之外,剩余的字符(即非最长重复字符)数量不超过 kk 个。

这样我们可以想到使用双指针维护这些区间,每次右指针右移,如果区间仍然满足条件,那么左指针不移动,否则左指针至多右移一格,保证区间长度不减小。

虽然这样的操作会导致部分区间不符合条件,即该区间内非最长重复字符超过了 kk 个。但是这样的区间也同样不可能对答案产生贡献。当我们右指针移动到尽头,左右指针对应的区间的长度必然对应一个长度最大的符合条件的区间。

实际代码中,由于字符串中仅包含大写字母,我们可以使用一个长度为 2626 的数组维护每一个字符的出现次数。每次区间右移,我们更新右移位置的字符出现的次数,然后尝试用它更新重复字符出现次数的历史最大值,最后我们使用该最大值计算出区间内非最长重复字符的数量,以此判断左指针是否需要右移即可。

注意点:
1.滑动窗口只会变大。不会变小。
2.每循环一次,右指针一定右滑一次。左指针可能右滑一次,可能不滑动。
3.最大字符数,是各个历史窗口的最大字符数。

代码用golang编写,代码如下:

```go
func characterReplacement(s string, k int) int {
    sLen := len(s)
    //记录次数的字典表
    dict := make([]int, 256)
    //记录窗口的最大字符数,可能是历史窗口最大字符数
    maxCount := 0
    L := 0
    for R := 0; R < sLen; R++ {
        dict[s[R]]++
        if maxCount < dict[s[R]] {
            maxCount = dict[s[R]]
        }
        //左指针要么右滑一次,要么不滑。也就是说,滑动窗口只会变大,不会变小
        if R-L+1-maxCount > k {
            dict[s[L]]--
            L++
        }
    }
    return sLen - L
}
```
执行结果如下:

***
[力扣:424. 替换后的最长重复字符](https://leetcode-cn.com/problems/longest-repeating-character-replacement/)
[评论](https://user.qzone.qq.com/3182319461/blog/1612220668)

【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。