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

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

福大大架构师每日一题 文章被收录于专栏

最新面试题,针对高级开发人员和架构师。内容是后端、大数据和人工智能。

全部评论

相关推荐

书海为家:实习是成为大厂正式员工很好的敲门砖,看您的简历中有一段实习经历,挺好的。我来给一点点小建议,因为毕竟还在学校不像工作几年的老鸟有丰富的项目经验,面试官在面试在校生的时候更关注咱们同学的做事逻辑和思路,所以最好在简历中描述下自己实习时做过项目的完整过程,比如需求怎么来的,你对需求的解读,你想到的解决办法,遇到困难如何找人求助,最终项目做成了什么程度,你从中收获了哪些技能,你有什么感悟。
点赞 评论 收藏
分享
评论
3
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务