第八章 贪心算法 part05(● 435. 无重叠区间 ● 763.划分字母区间 ● 56. 合并区间 )

学习目标:

● 435. 无重叠区间

● 763.划分字母区间

● 56. 合并区间


学习内容:● 435. 无重叠区间

https://programmercarl.com/0435.无重叠区间.html

csharp 复制代码
var eraseOverlapIntervals = function(intervals) {
    intervals.sort((a,b)=>{
       return a[0]-b[0]
    })
  
    if(intervals.length==1)return 0;
    let count = 0
    for(let i=1;i<intervals.length;i++){
        if(intervals[i][0]<intervals[i-1][1]){
            count++;
            intervals[i][1] = Math.min(intervals[i][1],intervals[i-1][1])
        }
    }
    return count
};

学习内容:● 763.划分字母区间

https://programmercarl.com/0763.划分字母区间.html

可以分为如下两步:

统计每一个字符最后出现的位置

从头遍历字符,并更新字符的最远出现下标,如果找到字符最远出现位置下标和当前下标相等了,则找到了分割点

csharp 复制代码
会思路,但是不会写,哈希
let hash = {}
    for(let i=0;i<s.length;i++){
        hash[s[i]]=i
}
csharp 复制代码
var partitionLabels = function(s) {
    let hash = {}
    for(let i=0;i<s.length;i++){
        hash[s[i]]=i
    }
    let result = [];
    let right=0,left=0;
    for(let i=0;i<s.length;i++){
        right = Math.max(hash[s[i]],right)
        if(right==i){
            result.push(right-left+1);
            left = i+1
        }
    }
    return result
};

学习内容:● 56. 合并区间

https://programmercarl.com/0056.合并区间.html

csharp 复制代码
result直接先插入intervals[0],在判断重叠后合并,只判断右区间就可以,排序后左区间一定是最小的,直接操作result就可以
csharp 复制代码
var merge = function(intervals) {
    if(intervals.length<=1)return intervals;
    intervals.sort((a,b)=>{
        return a[0]-b[0]
    })
    let result =[intervals[0]]
    for(let i=1;i<intervals.length;i++){
        if(intervals[i][0]<=result[result.length-1][1]){          
            // intervals[i][0] = Math.min(intervals[i][0],result[result.length-1][0])不用合并,一定是最小的
           result[result.length-1][1] = Math.max(intervals[i][1],result[result.length-1][1])
        }else{
            result.push(intervals[i])
        }       
    }
    return result
};

相关推荐
侯小啾2 小时前
【03】C语言 强制类型转换 与 进制转换
c语言·数据结构·算法
Xの哲學3 小时前
Linux NAPI 架构详解
linux·网络·算法·架构·边缘计算
京东零售技术6 小时前
扛起技术大梁的零售校招生们 | 1024技术人特别篇
算法
爱coding的橙子7 小时前
每日算法刷题Day78:10.23:leetcode 一般树7道题,用时1h30min
算法·leetcode·深度优先
Swift社区7 小时前
LeetCode 403 - 青蛙过河
算法·leetcode·职场和发展
地平线开发者7 小时前
三种 Badcase 精度验证方案详解与 hbm_infer 部署实录
算法·自动驾驶
papership7 小时前
【入门级-算法-5、数值处理算法:高精度的减法】
算法·1024程序员节
lingran__7 小时前
算法沉淀第十天(牛客2025秋季算法编程训练联赛2-基础组 和 奇怪的电梯)
c++·算法
DuHz7 小时前
基于MIMO FMCW雷达的二维角度分析多径抑制技术——论文阅读
论文阅读·物联网·算法·信息与通信·毫米波雷达
Dragon_D.8 小时前
排序算法大全——插入排序
算法·排序算法·c·学习方法