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

【LeetCode】每日一题 2024_9_27 每种字符至少取 K 个(双指针)

前言

每天和你一起刷 LeetCode 每日一题~

LeetCode 启动!

题目:每种字符至少取 K 个

代码与解题思路

func takeCharacters(s string, k int) int {
    // 核心思路:
    // 题目要求字符串 s 中,每种字符都取至少 k 个
    // 而且可以从头取,也可以从尾巴取,找出取的时间最短的方法
    // 不妨试着先从尾巴开始取,直到达成题目的要求(达不成就直接返回 -1 即可)
    // 然后再从头开始取,用滑动窗口的思想,找出:“需要的 最少 分钟数”(最优情况)

    n := len(s)
    // 由字符 'a'、'b'、'c' 组成的字符串 s,所以 cnt 只用记录者三种字符即可
    cnt, l := [3]int{}, n
    for cnt[0] < k || cnt[1] < k || cnt[2] < k {
        if l == 0 { // 达不成要求,直接返回 -1
            return -1
        }
        l--
        cnt[s[l]-'a']++
    }
    
    ans := n-l // 目前需要的分钟数
    // 滑动窗口,或者说双指针
    for r := range s { // 维护 cnt 数组中这三个字符的数量,更新子串的最小值
        cnt[s[r]-'a']++
        for l < n && cnt[s[l]-'a'] > k {
            cnt[s[l]-'a']--
            l++
        }
        ans = min(ans, n-l + r+1) // 头的长度 + 尾的长度
    }
    return ans
}

今天这道题目比较难想,是力扣之前的一道周赛题,我曾经做过,所以才有思路,如果第一次做大概也做不太出来

核心思路如注释

这道题的难点就在于,题目要求子串的最小值,但是可以从字符串的头开始,也可以从尾开始,两头加在一起的最小值,怎么样才能判断出来呢?

下次遇到这种类型的题目就知道该怎么操作了,既然头尾都可以,那就先全用尾巴的子串,然后再起一个循环,遍历头部的子串来维护整体长度的最小值


题外话

最近在刷字节青训营给的题目,据说这些题目都是字节曾经出过的笔试面试的真题,到时候我做出一定成果了就来分享一下~

视频实况

【【LeetCode】每日一题 2024_9_27 每种字符至少取 K 个(双指针)】

每天进步一点点

可以和我刷一辈子的每日一题吗?
一题一题,积累起来就是一辈子。


http://www.kler.cn/news/328075.html

相关文章:

  • Android 安装应用-提交阶段之后剩下的操作
  • uniapp生物识别示例(人脸识别、指纹识别)
  • 【docker】docker常见命令
  • 动态分配内存
  • Gin框架简易搭建(3)--Grom与数据库
  • 归并排序【C语言版-笔记】
  • Unreal 实现建造游戏|地面交互shader
  • 06.C/C++内存管理
  • 【数据库】MongoDB 用户权限与数据之间的关系详解
  • Android studio配置AVD虚拟机
  • 【60天备战2024年11月软考高级系统架构设计师——第33天:云计算与大数据架构——大数据处理框架的应用场景】
  • 关于Java中的List<User>如何进行深拷贝
  • 贝锐蒲公英工业物联方案:助力美的智慧楼宇全球布局
  • Leetcode 611. 有效三角形的个数
  • 前端面试题(八)
  • 音视频入门基础:FLV专题(7)——Tag header简介
  • 【STM32单片机_(HAL库)】4-1【定时器TIM】定时器中断点灯实验
  • 【漏洞复现】JeecgBoot 积木报表 queryFieldBySql sql注入漏洞
  • 【进阶OpenCV】 (2)--Harris角点检测
  • 衡水中学资料大全-重构版(状元、学霸笔记)
  • .NET MAUI(.NET Multi-platform App UI)下拉选框控件
  • UE5: Content browser工具编写02
  • 【抽代复习笔记】29-群(二十三):生成子群的两道例题及子群陪集的定义
  • hdlbits系列verilog解答(Exams/m2014 q3)-77
  • 【qt】QQ仿真项目1
  • 【洛谷】P4551 最长异或路径 的题解
  • 自然语言处理的应用领域有哪些?
  • 【漏洞复现】孚盟云oa AjaxSendDingdingMessage接口 存在sql注入漏洞
  • 云计算 Cloud Computing
  • 前端——DOM与BOM总结