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

leetcode76-最小覆盖子串

leetcode 76

在这里插入图片描述
本题也是利用滑动窗口来解决,利用哈希表来记录t中每个字符的数量匹配,大于0表示缺少,小于0表示过剩,todo来记录总共还缺少的字母数量。
假设t = aabc,初始时t = 4,需要4个字母,map{a=>2,b=>1,c=>1}。如果匹配到了一个b,那么todo就要减少todo = 3,map{a=>2,b=>0,c=>1},下次再匹配到b,此时todo不需要减少,因为b已经是0,也就是说b已经被覆盖了,当前需要的是a和c,所以todo不改变,因为map是记录在窗口内每个字母出现的频次,所以只要匹配到这个字符是t内的字符都要变更记录map{a=>2,b=>-1,c=>1}

var minWindow = function (s, t) {
    if(s.length < t.length) return "";
    let todo = t.length; // 记录还差多少个字母
    let map = frequencyMap(t);
    let slow = 0; // 左滑窗
    let result;
    for (let i = 0; i < s.length; i++) {
        const item = s[i];
        if (map.has(item)) { // 需要的字母
            if (map.get(item) > 0) { // 判断此字母是否还缺少
                todo--;
            }
            // 更新字母频次
            map.set(item, map.get(item) - 1);
            while (todo === 0) { // 覆盖所有子串,左窗口滑动缩小范围
                // 记录最小子串
                let ans = s.slice(slow, i + 1);
                if (!result || ans.length <= result.length) {
                    result = ans
                }
                if(map.has(s[slow])){
                    map.set(s[slow],map.get(s[slow])+1);
                    if(map.get(s[slow]) > 0){
                        todo++
                    }
                }
                slow++
            }
        }
    }
    return result || "";
};
// 记录每个字母需要出现的频数
function frequencyMap(s){
    const map = new Map();
    for (const item of s) {
        map.set(item, (map.get(item) || 0) + 1);
    }
    return map;
}

http://www.kler.cn/a/509851.html

相关文章:

  • openwrt下oaf插件编译安装,实现上网行为监控
  • 搜维尔科技:Xsens人形机器人解决方案的优势
  • RC2在线加密工具
  • 开发神器之cursor
  • 深入理解 SQL 中的 DATEDIFF 函数
  • 【21】Word:德国旅游业务❗
  • 在 Web 应用中集成多种地图 API 的实现与管理
  • WinForm实现无边框拖动的两种方式
  • 三台 Centos7.9 中 Docker 部署 Redis 哨兵模式
  • 每日十题八股-2025年1月18日
  • VScode侧边栏左下角,没有NPM脚本,如何打开???
  • 代码随想录刷题day11|(链表篇)206.翻转链表
  • 20250118在excel中使用公式的时候如何直接拖拽全部到最后
  • ubuntu安全配置基线
  • 蓝桥杯训练—字符串对比
  • Git代码管理工具 — 5 GitHub远程仓库
  • 将.ext4文件挂载在ubuntu系统本地的步骤和方法
  • Redis 部署模式
  • Pandas库的常用内容归纳
  • [LeetCode] 链表完整版 — 虚拟头结点 | 基本操作 | 双指针法 | 递归
  • 安路FPGA开发工具TD:问题解决办法 及 Tips 总结
  • 鲍厚霖:引领AI广告创新,搭建中美合作桥梁
  • Python 的 WebSocket 实现详解
  • mysql 创建临时表报错
  • Spring boot框架下的RocketMQ消息中间件
  • 解析Three.js中几何体是如何构建的--BufferGeometry(四)