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

福大大架构师每日一题 · · 515 次点击 · · 开始浏览    
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

福哥答案2021-02-02:

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

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

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

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

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

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

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. 替换后的最长重复字符
评论


有疑问加站长微信联系(非本文作者)

本文来自:简书

感谢作者:福大大架构师每日一题

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

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

515 次点击  
加入收藏 微博
下一篇:gRPC
暂无回复
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传