记力扣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

难点:

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

相关推荐
Dingdangcat862 小时前
城市交通多目标检测系统:YOLO11-MAN-FasterCGLU算法优化与实战应用_3
算法·目标检测·目标跟踪
tang&3 小时前
滑动窗口:双指针的优雅舞步,征服连续区间问题的利器
数据结构·算法·哈希算法·滑动窗口
拼命鼠鼠3 小时前
【算法】矩阵链乘法的动态规划算法
算法·矩阵·动态规划
LYFlied3 小时前
【每日算法】LeetCode 17. 电话号码的字母组合
前端·算法·leetcode·面试·职场和发展
式5164 小时前
线性代数(八)非齐次方程组的解的结构
线性代数·算法·机器学习
橘颂TA5 小时前
【剑斩OFFER】算法的暴力美学——翻转对
算法·排序算法·结构与算法
叠叠乐5 小时前
robot_state_publisher 参数
java·前端·算法
hweiyu005 小时前
排序算法:冒泡排序
算法·排序算法
brave and determined5 小时前
CANN训练营 学习(day9)昇腾AscendC算子开发实战:从零到性能冠军
人工智能·算法·机器学习·ai·开发环境·算子开发·昇腾ai
Dave.B5 小时前
用【vtk3DLinearGridCrinkleExtractor】快速提取3D网格相交面
算法·3d·vtk