记力扣2516.每种字符至少取k个 练习理解

给你一个由字符 'a''b''c' 组成的字符串 s 和一个非负整数 k 。每分钟,你可以选择取走 s 最左侧 还是 最右侧 的那个字符。

你必须取走每种字符 至少 k 个,返回需要的 最少 分钟数;如果无法取到,则返回-1
思路:

考虑到从正面做(即统计所有字符的数量然后分别从最左边遍历和右边遍历去减去总数,相对有点复杂),采用正难则反的办法,题目需要返回最少分钟数,我变相求出最长的数组且保证剩余k个所求每种字符即可,最后返回n-max_len即为最少分钟数

复制代码
from collections import counter
class Solution:
    def takeCharacters(self,s:str,k:int)->int:
        cnt=counter(s)
        n=len(s)
        max_len=left=0
        if any(cnt[c]<k for c in "abc"):
            return -1
        for i,char in enumerate(s):
            cnt[char] -=1
            while cnt[char]<k:
                cnt[s[left]]+=1
                left +=1
            max_len=max(max_len,i-left+1)
        return n-max_len

难点:

我认为是能够想到这种办法,这种正难则反的思路,认识到 "最少取出字符数" 等价于 "最多保留字符数",而 "最多保留字符数" 又等价于 "从原始字符串中移除一段连续子串后剩下的字符数最多"

相关推荐
心中有国也有家9 分钟前
PaddlePaddle 适配 NPU 的技术全解析——从算子接入到端到端性能优化
人工智能·分布式·算法·性能优化·架构·paddlepaddle
兰令水10 分钟前
topcode【随机算法题】【2026.5.24打卡-java版本】
java·开发语言·算法
徐小夕29 分钟前
面试官:AI生成到90%突然断了,你的解决方案是什么?(万字长文深度剖析)
前端·vue.js·算法
EnCi Zheng32 分钟前
09a-斯坦福 CS336 作业一:BPE分词器
开发语言·python·算法
生成论实验室1 小时前
用事件关系网络重新理解AI(二):损失函数、优化器与深度学习的动力学
数据结构·人工智能·深度学习·算法·语言模型
霍霍的袁1 小时前
【C++初阶】缺省参数(默认参数)详细讲解
开发语言·c++·算法
秦明月131 小时前
电气安全回路设计实战:皮尔兹安全继电器应用
经验分享·笔记·安全·职场和发展·创业创新·学习方法
计算机安禾1 小时前
【算法分析与设计】第2篇:计算模型与渐进复杂性分析
算法
生成论实验室1 小时前
事件、信息荷与六维态势空间——每一个事件都是一次空间的弯曲
人工智能·算法·语言模型·可信计算技术·安全架构
budingxiaomoli1 小时前
递归,搜索与回溯算法--递归
算法