当前位置: 首页 > news >正文

LeetCode 424. Longest Repeating Character Replacement

LeetCode 424. Longest Repeating Character Replacement

https://leetcode.com/problems/longest-repeating-character-replacement/

题目描述

You are given a string s and an integer k. You can choose any character of the string and change it to any other uppercase English character. You can perform this operation at most k times.

Return the length of the longest substring containing the same letter you can get after performing the above operations.

思路

  1. 滑动窗口
  2. 用一个map记录窗口中每个字符出现的次数, 取名fre
  3. 用一个变量记录窗口中出现次数最多的字符的次数, 取名maxCount
  4. 如果窗口的长度减去出现次数最多的字符的次数大于k,那么就需要移动左指针,直到窗口的长度减去出现次数最多的字符的次数小于等于k
    • 例如:s = “AABABBA”, k = 1, 当窗口为[0, 2]时,map中记录的字符出现的次数为{‘A’: 2, ‘B’: 1}, maxCount = 2, 此时窗口的长度减去出现次数最多的字符的次数为2(right) - 0(left) + 1 - 2(maxCount) = 1 == 1(k), 此时窗口的长度减去出现次数最多的字符的次数小于等于k, 不需要移动左指针
  5. 每次移动左指针时,需要将左指针指向的字符在map中的次数减1, left++
  6. 每次移动右指针时,需要将右指针指向的字符在map中的次数加1, right++
  7. 每次移动左指针或者右指针时,都需要更新maxCount, maxCount = max(maxCount, fre[s[right]])

数据结构

var (size     = len(s) // s字符串的长度fre      = make(map[byte]int, 26) // map记录窗口中每个字符出现的次数, 因为题目中说了只有大写字母,所以map的长度为26maxLen   = 0 // 最长的子串的长度maxCount = 0 //  窗口中出现次数最多的字符的次数)

算法

func characterReplacement(s string, k int) int {for left, right := 0, 0; right < size; right++ {fre[s[right]]++               // 右指针指向的字符在map中的次数加1if maxCount < fre[s[right]] { // 更新maxCountmaxCount = fre[s[right]]}if right-left+1-maxCount > k { // 如果窗口的长度减去出现次数最多的字符的次数大于k,那么就需要移动左指针fre[s[left]]-- // 左指针指向的字符在map中的次数减1left++         // 窗口左指针右移}if maxLen < right-left+1 { // 更新maxLenmaxLen = right - left + 1}}return maxLen
}
http://www.lryc.cn/news/38858.html

相关文章:

  • 建立自己的博客(记录-不推荐)
  • hashmap存储方式 hash碰撞及其解决方式
  • Amazon GuardDuty 的新增功能 – Amazon EBS 卷的恶意软件检测
  • YOLOv7 pytorch
  • JDK自带JVM分析工具
  • IO多路复用--[select | poll | epoll | Reactor]
  • pod的requests、limits解读、LimitRange资源配额、Qos服务质量等级、资源配额管理 Resource Quotas
  • R语言基础(六):函数
  • [C++] 简单序列化
  • Autosar Configuration(十三)SomeIP之配置TCP/IP
  • 滤波算法 | 无迹卡尔曼滤波(UKF)算法及其Python实现
  • IMU 积分的误差状态空间方程推导
  • VirtualBox的克隆与复制
  • 每天5分钟玩转机器学习算法:逆向概率的问题是什么?贝叶斯公式是如何解决的?
  • 游戏闲聊之游戏是怎么赚钱的
  • Redis高频面试题汇总(下)
  • Windows修改Docker安装目录修改Docker镜像目录,镜像默认存储位置存放到其它盘
  • 376. 摆动序列——【Leetcode每日刷题】
  • mgre实验
  • 一文彻底了解Zookeeper(介绍篇)
  • 1. ELK Stack 理论篇之什么是ELK Stack?
  • 两道有关链表的练习
  • Python uiautomator2安卓自动化测试
  • Leetcode. 160相交链表
  • MDPs —— 马尔可夫决策定义与算法
  • 【C++】图
  • 尾递归优化
  • P1120 小木棍(搜索+剪枝)
  • 【专项训练】动态规划-3
  • 【Linux】信号+再谈进程地址空间