3-合并区间

1题目描述

在这里插入图片描述

2思路

  1. 在合并区间之前,需要对所有的区间按照区间第一个元素进行排序,这样可以保证已经合并的各个区间之后不会再包含其他区间,或者被其他区间包含;
    1. 首先自己进行一下排序练习,回顾冒泡排序和选择排序,详见3.1使用排序算法对区间进行排序;
  2. 在合并时,核心思想就是:准备一个空的列表,每次合并都取列表中最后一个区间去和当前待加入的区间进行合并;因为区间已经排过序了,所以列表中非最后一个元素与当前待加入的区间肯定是没有重叠的;详见3.2合并区间;

3实现

3.1使用排序算法对区间进行排序

Anchor1

  1. 冒泡排序和选择排序的动态执行过程详见:冒泡排序和选择排序_选择排序和冒泡排序-CSDN博客;

3.1.1冒泡排序

  1. 核心思想:

    1. 两层循环:外层循环控制趟数,内层循环控制每一趟比较的次数;
    2. 两两比较,即时交换
  2. 应用到区间排序上,代码如下:

    from typing import List
    
    
    class Solution:
        def merge1(self, intervals: List[List[int]]) -> List[List[int]]:
            # 先排序,按照每个区间的左侧数值升序排序,使用冒泡排序
            # 外层循环控制排序的轮数
            for i in range(0, len(intervals) - 1):
                # 内层循环控制每一轮的比较次数
                for j in range(0, len(intervals) - 1 - i):
                    # 相邻元素两两比较,升序排列
                    if intervals[j][0] > intervals[j + 1][0]:
                        intervals[j], intervals[j + 1] = intervals[j + 1], intervals[j]
            print("冒泡排序结果:", intervals)
    # 主函数
    if __name__ == '__main__':
        # intervals = [[1,3],[2,6],[8,10],[15,18]]
        # intervals = [[1, 3], [8, 10], [15, 18], [2, 6]]
        intervals = [[1, 3], [16, 10], [15, 18], [2, 6]]
        solution = Solution()
        solution.merge1(intervals)
        
        # print(result)
    

    在这里插入图片描述

    在这里插入图片描述

3.1.2选择排序

  1. 核心思想:

    1. 两层循环:外层循环控制轮数(或者说固定住然后待比较的数),内层循环控制每一轮比较的次数(或者说控制当前参与比较的数)
    2. 每一轮,固定住某一个数,然后看之后的数是否比这个数大(小),如果是,则更新最大(小)的索引;最后完成交换;
  2. 应用到区间排序上,代码如下:

    from typing import List
    
    
    class Solution:
        def merge2(self, intervals: List[List[int]]) -> List[List[int]]:
            # 先排序,按照每个区间的左侧数值升序排序,使用选择排序
            for i in range(0, len(intervals) - 1):
                min_index = i  # 记录最小值的索引
                for j in range(i + 1, len(intervals)):
                    if intervals[j][0] < intervals[min_index][0]:
                        min_index = j  # 更新最小值的索引
                if min_index != i:
                    # 最小值不是当前i索引对应的值,交换
                    intervals[i], intervals[min_index] = intervals[min_index], intervals[i]
            print("选择排序结果:", intervals)
    
    
    # 主函数
    if __name__ == '__main__':
        # intervals = [[1,3],[2,6],[8,10],[15,18]]
        # intervals = [[1, 3], [8, 10], [15, 18], [2, 6]]
        # intervals = [[1, 3], [2, 10], [15, 18], [2, 6]]
        intervals = [[1, 3], [2, 5], [15, 18], [2, 6]]
        solution = Solution()
        solution.merge2(intervals)
        # print(result)
    
    

    在这里插入图片描述

    在这里插入图片描述

3.2合并区间

Anchor2

  1. 主要思路:准备一个空列表sorted_list,比较前一个区间的右侧数值和当前区间的左侧数值,如果前一个区间的右侧数值小于当前区间的左侧数值,则两个区间不重叠,直接添加进来;否则重叠,需要更新sorted_list中最后一个区间的右侧数值;

  2. 代码如下:

    from typing import List
    
    
    class Solution:
        def merge1(self, intervals: List[List[int]]) -> List[List[int]]:
            # 先排序,按照每个区间的左侧数值升序排序,使用冒泡排序
            # 外层循环控制排序的轮数
            for i in range(0, len(intervals) - 1):
                # 内层循环控制每一轮的比较次数
                for j in range(0, len(intervals) - 1 - i):
                    # 相邻元素两两比较,升序排列
                    if intervals[j][0] > intervals[j + 1][0]:
                        intervals[j], intervals[j + 1] = intervals[j + 1], intervals[j]
            print("冒泡排序结果:", intervals)
    
            # 合并区间
            sorted_list = []
            for item in intervals:
                # 空列表被视为False,非空列表被视为True
                if not sorted_list or sorted_list[-1][-1] < item[0]:
                    # 比较前一个区间的右侧数值和当前区间的左侧数值,如果前一个区间的右侧数值小于当前区间的左侧数值,则两个区间不重叠
                    sorted_list.append(item)
                else:
                    # 重叠则需要更新sorted_list中最后一个区间的右侧数值
                    sorted_list[-1][1] = max(sorted_list[-1][-1], item[1])
            return sorted_list
    
    
    # 主函数
    if __name__ == '__main__':
        # intervals = [[1,3],[2,6],[8,10],[15,18]]
        intervals = [[1, 3], [8, 10], [15, 18], [2, 6]]
        # intervals = [[1, 3], [2, 10], [15, 18], [2, 6]]
        # intervals = [[1, 3], [2, 5], [15, 18], [2, 6]]
        solution = Solution()
        sorted_list = solution.merge1(intervals)
        print("合并区间结果:", sorted_list)
        # solution.merge2(intervals)
        # print(result)
    
    
  3. 在力扣上执行,提示超出时间限制,可见这里使用冒泡排序的时候,两层循环的嵌套增加了算法的复杂度;

3.3排序算法修改

  1. 前面是自己实现了冒泡排序或者选择排序,其实python中的列表有封装好的排序算法
  1. 这里使用封装好的排序算法,即list中封装的sort函数:

    1. 只需执行:intervals.sort(key=lambda x: x[0]);key用于指定一个函数,这个函数会被应用到列表中的每一个元素上,获取用于排序的键;
    2. 关于此函数:

    在这里插入图片描述

  2. 因此,最终的合并区间的算法代码为:

    from typing import List
    
    
    class Solution:
        def merge1(self, intervals: List[List[int]]) -> List[List[int]]:
            # 先排序,按照每个区间的左侧数值升序排序
            intervals.sort(key=lambda x: x[0])
    
            # 合并区间
            sorted_list = []
            for item in intervals:
                # 空列表被视为False,非空列表被视为True
                if not sorted_list or sorted_list[-1][-1] < item[0]:
                    # 比较前一个区间的右侧数值和当前区间的左侧数值,如果前一个区间的右侧数值小于当前区间的左侧数值,则两个区间不重叠
                    sorted_list.append(item)
                else:
                    # 重叠则需要更新sorted_list中最后一个区间的右侧数值
                    sorted_list[-1][1] = max(sorted_list[-1][-1], item[1])
            return sorted_list
    
    
    # 主函数
    if __name__ == '__main__':
        # intervals = [[1,3],[2,6],[8,10],[15,18]]
        intervals = [[1, 3], [8, 10], [15, 18], [2, 6]]
        # intervals = [[1, 3], [2, 10], [15, 18], [2, 6]]
        # intervals = [[1, 3], [2, 5], [15, 18], [2, 6]]
        solution = Solution()
        sorted_list = solution.merge1(intervals)
        print("合并区间结果:", sorted_list)
        # solution.merge2(intervals)
        # print(result)
    
  3. 然后,就不会超出时间限制了:

    在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/179075.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Leetcode——121 买卖股票的最佳时机

(超时。。。。。。&#xff09;除了暴力法我是真的。。。。。。 class Solution {public int maxProfit(int[] prices) {int len prices.length;int max0;for(int i0;i<len-1;i){for(int ji1;j<len;j){int income prices[j] - prices[i];if(income>max){maxincome;…

真实网络中的 bbr

本文包含中心极限定理&#xff0c;大数定律&#xff0c;经济规律等&#xff0c;bbr 倒没多少&#xff0c;不过已经习惯把 bbr 当靶子了。 上周写了 揭秘 bbr 以及 抢带宽的原理&#xff0c;我对自己说&#xff0c;这都是理论上如何&#xff0c;可实际上呢。于是有必要结合更实际…

基于VM虚拟机下Ubuntu18.04系统,Hadoop的安装与详细配置

参考博客&#xff1a; https://blog.csdn.net/duchenlong/article/details/114597944 与上面这个博客几乎差不多&#xff0c;就是java环境配置以及后面的hadoop的hdfs-site.xml文件有一些不同的地方。 准备工作 1.更新 # 更新 sudo apt update sudo apt upgrade2.关闭防火…

数据结构-栈的实现

1.栈的概念及结构 栈&#xff1a;一种特殊的线性表&#xff0c;其只允许在固定的一端进行插入和删除元素操作。进行数据插入和删除操作的一端称为栈顶&#xff0c;另一端称为栈底。栈中的数据元素遵守后进先出LIFO&#xff08;Last In First Out&#xff09;的原则。 压栈&…

git-2

1.分离头指针情况下的注意事项 分离头指针指的是变更没有基于某个branch去做&#xff0c;所以当进行分支切换的时候&#xff0c;在分离头指针上产生的commit&#xff0c;很可能会被git当作垃圾清理掉&#xff0c;如果你认为是重要的内容&#xff0c;切记需要绑定分支 2.进一步…

NFC:应用场景广泛的短距离通信技术

NFC&#xff1a;应用场景广泛的短距离通信技术 一、NFC 技术介绍1.1 NFC 技术应用场景1.2 NFC 技术优点1.3 NFC 工作原理 二、NFC 开发2.1 NFC 应用开发流程2.2 NFC 读取和写入2.3 NFC 读写功能示例 三、总结 一、NFC 技术介绍 NFC &#xff08;Near-field communication&…

hadoop在本地创建文件,然后将文件拷贝/上传到HDFS

1.要$cd {对应目录}进入到对应目录&#xff0c;一般为 cd /usr/local/hadoop/ 2.创建文件&#xff0c;$sudo gedit {文件名}&#xff0c;例 sudo gedit test.txt 然后在弹出的txt文件输入内容&#xff0c;点击右上角的保存之后&#xff0c;关闭即可。 3.拷贝本地文件到HDF…

机器学习第12天:聚类

文章目录 机器学习专栏 无监督学习介绍 聚类 K-Means 使用方法 实例演示 代码解析 绘制决策边界 本章总结 机器学习专栏 机器学习_Nowl的博客-CSDN博客 无监督学习介绍 某位著名计算机科学家有句话&#xff1a;“如果智能是蛋糕&#xff0c;无监督学习将是蛋糕本体&a…

sql语法大全

1&#xff0c;创建数据库 create database 数据库名字; 2,查看所有的数据库名称 show databases; MySQL服务器已有4个数据库&#xff0c;这些数据库都是MySQL安装时自动创建的。 information_schema 和 performance_schema 数据库分别是 MySQL 服务器的数据字典&#xff08;…

everything排除目录

everything默认搜索所有文件&#xff0c;自己把没啥必要的目录都屏蔽掉&#xff0c;记录如下

分享一篇很就以前的文档-VMware Vsphere菜鸟篇

PS&#xff1a;由于内容是很久以前做的记录&#xff0c;在整理过程中发现了一些问题&#xff0c;简单修改后分享给大家。首先ESXI节点和win7均运行在VMware Workstation上面&#xff0c;属于是最底层&#xff0c;而新创建的CentOS则是嵌套后创建的操作系统&#xff0c;这点希望…

基于金枪鱼群算法优化概率神经网络PNN的分类预测 - 附代码

基于金枪鱼群算法优化概率神经网络PNN的分类预测 - 附代码 文章目录 基于金枪鱼群算法优化概率神经网络PNN的分类预测 - 附代码1.PNN网络概述2.变压器故障诊街系统相关背景2.1 模型建立 3.基于金枪鱼群优化的PNN网络5.测试结果6.参考文献7.Matlab代码 摘要&#xff1a;针对PNN神…

transformer之KV Cache

一、为什么要研究KV Cache 非常有效的加速推理速度&#xff0c;效果如下所示&#xff1a; import numpy as np import time import torch from transformers import AutoModelForCausalLM, AutoTokenizer NAME_OR_PATH r*************** device "cuda" if torch.cu…

SpringBoot——启动类的原理

优质博文&#xff1a;IT-BLOG-CN SpringBoot启动类上使用SpringBootApplication注解&#xff0c;该注解是一个组合注解&#xff0c;包含多个其它注解。和类定义SpringApplication.run要揭开SpringBoot的神秘面纱&#xff0c;我们要从这两位开始就可以了。 SpringBootApplicati…

用友NC Cloud uploadChunk任意文件上传漏洞复现 [附POC]

文章目录 用友NC Cloud uploadChunk任意文件上传漏洞复现 [附POC]0x01 前言0x02 漏洞描述0x03 影响版本0x04 漏洞环境0x05 漏洞复现1.访问漏洞环境2.构造POC3.复现 0x06 修复建议 用友NC Cloud uploadChunk任意文件上传漏洞复现 [附POC] 0x01 前言 免责声明&#xff1a;请勿利…

AT89S52单片机的最小应用系统

目录 ​一.时钟电路设计 1.内部时钟方式 2.外部时钟方式 3.时钟信号的输出 二.机器周期&#xff0c;指令周期与指令时序 1.时钟周期 2.机器周期 3.指令周期 三.复位操作和复位电路 1.复位操作 2 复位电路设计 四.低功耗节电模式 AT89S52本身片内有8KB闪烁存储器&am…

【AI】行业消息精选和分析(11月22日)

今日动态 &#x1f453; Video-LLaVA&#xff1a;视觉语言模型革新&#xff1a; - 图像和视频信息转换为文字格式。 - 多模态理解能力&#xff0c;适用于自动问答系统等。 &#x1f4c8; 百度文心一言用户数达7000万&#xff1a; &#x1f50a; RealtimeTTS&#xff1a;实时文本…

乐划锁屏插画大赏热度持续,进一步促进价值内容的创造与传播

锁屏,原本只是为了防止手机在口袋里“误触”而打造的功能,现如今逐渐成为文化传播领域的热门入口。乐划锁屏不断丰富锁屏内容和场景玩法,通过打造“乐划锁屏插画大赏”系列活动为广大内容创作者提供了更多展示自我的机会,丰富平台内容。 从2020年到2023年,乐划锁屏插画大赏已连…

什么是Zero-shot(零次学习)

1 Zero-shot介绍 Zero-shot学习&#xff08;ZSL&#xff09;是机器学习领域的一种先进方法&#xff0c;它旨在使模型能够识别、分类或理解在训练过程中未见过的类别或概念。这种学习方法对于解决现实世界中常见的长尾分布问题至关重要&#xff0c;即对于一些罕见或未知类别的样…

万界星空科技QMS质量管理系统介绍

QMS&#xff08;Quality Management System&#xff09;质量管理系统是五大基础系统之一&#xff0c;在工业企业中被广泛的应用&#xff0c;在质量策划、生产过程质量监督、体系审核和文档管理等业务上发挥着不可替代的作用。 一般制造业工厂现状&#xff1a;质量成本高&#x…