第八章 贪心算法 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
};

相关推荐
BD4SXV5 分钟前
线性二次调节器(Linear Quadratic Regulator,LQR)的无限时域最优控制求解与黎卡提方程
算法·自动化
ST——Jess13 分钟前
2026年度传统文化数字化与命理科技(Ethno-tech)行业趋势研究报告:专业级数智工作台的技术壁垒与评测标准
人工智能·科技·算法·架构
Matrix_1136 分钟前
第13篇:非线性位移场——漩涡、鱼眼、水波纹与球面化
图像处理·算法
金牌归来发现妻女流落街头38 分钟前
【LeetCode 第207题】
算法·leetcode·拓扑·领接表
熬夜敲代码的猫44 分钟前
AVL树(C++详解版)
数据结构·c++·算法
-To be number.wan1 小时前
算法日记 | STL-MAP
c++·算法
cjp5601 小时前
015. UG 二次开发,拉伸草图生成实体类,高级草图类封装
算法
Eric 辰东1 小时前
【C 语言程序的编译和链接】详解编译链接过程
c语言·笔记·算法·学习方法
迈巴赫车主1 小时前
蓝桥杯21247弹跳鞋java
java·开发语言·数据结构·算法·职场和发展·蓝桥杯
jghhh012 小时前
基于 Weiler-Atherton 算法的多边形裁剪程序实现
算法