LeetCode435无重叠区间

题目描述

  给定一个区间的集合 intervals ,其中 intervals[i] = [starti, endi] 。返回 需要移除区间的最小数量,使剩余区间互不重叠 。

解析

  由于要删除尽可能少的区间 ,因此区间跨度大的一定是要先删除的,这样就有两种贪心思想了。按照区间结束的时间排序,遇到冲突直接删除,保证优先删除的结束区间是小的。或者按照区间开始时间,在删除的时候,选择删除更大结束时间的那个区间。

public static int eraseOverlapIntervals(int[][] intervals) {if (intervals.length == 0) return 0;// 按照左端点排序Arrays.sort(intervals, Comparator.comparingInt(a -> a[0]));int res = 0;int curRight = intervals[0][1];for(int i = 0; i < intervals.length - 1; i++) {if(curRight > intervals[i + 1][0]) {curRight = Math.min(intervals[i + 1][1], curRight);res++;}else {curRight = intervals[i + 1][1];}}return res;/*// 按右端点排序Arrays.sort(intervals, Comparator.comparingInt(a -> a[1]));int res = 0;int curRight = intervals[0][1];for (int i = 1; i < intervals.length; i++) {if (intervals[i][0] < curRight) {// 有重叠,增加删除计数res++;} else {// 更新当前不重叠区间的右端点curRight = intervals[i][1];}}return res;*/}

  优化方向则是排序的过程,使用sort函数实际上是使用归并排序去进行排序,时间复杂度为O(nlogn),如果使用基数排序,时间复杂度则是n*k,k为待排序的数的最多位数。

public int eraseOverlapIntervals(int[][] intervals) {radixSort(intervals);int count = 1;int right = intervals[0][1];for (int i = 1; i < intervals.length; i++) {if (intervals[i][0] >= right) {count++;right = intervals[i][1];}}return intervals.length - count;}private void radixSort(int[][] intervals) {if (intervals.length < 2) {return;}int max = intervals[0][0];for (int[] row : intervals) {max = Math.max(max, row[1]);}int digit = findDigit(max);int[] counts = new int[19];int[][] sort = new int[intervals.length][2];int div = 1;for (int i = 0; i < digit; i++) {for (int[] row : intervals) {counts[(row[1] / div) % 10 + 9]++;}for (int j = 1; j < counts.length; j++) {counts[j] += counts[j - 1];}for (int j = intervals.length - 1; j >= 0; j--) {sort[--counts[(intervals[j][1] / div) % 10 + 9]] = intervals[j];}div *= 10;Arrays.fill(counts, 0);System.arraycopy(sort, 0, intervals, 0, intervals.length);}}private int findDigit(int max) {int digit = 0;for (int i = max; i > 0; i /= 10) {digit++;}return digit;}

在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

API接口:解锁社交电商的创新潜力

摘要 在数字化营销的浪潮中&#xff0c;某音作为一个集社交与电商于一体的平台&#xff0c;其API接口为品牌和商家提供了前所未有的机遇。本文深入探讨了某音API接口如何助力社交电商&#xff0c;实现个性化营销和增强用户体验。 关键词 某音、​​API接口​​、社交电商、个…

FreeRtos-13资源管理

一、临界资源是什么 要独占式地访问临界资源,有3种方法: 1.公平竞争:比如使用互斥量,谁先获得互斥量谁就访问临界资源,这部分内容前面讲过。 谁要跟我抢,我就灭掉谁: 2.中断要跟我抢?我屏蔽中断 3.其他任务要跟我抢?我禁止调度器,不运行任务切换 二、暂停调度器…

API 类别 - 特效核心

API 类别 - 特效核心 引言 在当今的数字时代,应用程序编程接口(API)已成为软件开发和互联网服务的重要组成部分。API作为一种中间件,允许不同的软件系统之间进行交互和数据交换。其中,特效核心API是一类专门用于处理和渲染视觉特效的接口,广泛应用于游戏开发、视频编辑…

接口postman

前后端 前端&#xff1a;是肉眼所能见到的界面 后端&#xff1a;处理数据&#xff0c;数据逻辑 接口&#xff1a;提供前后端交互的通道 接口测试&#xff1a;校验接口返回的响应数据是否与预期的一致 接口测试可以绕过前端&#xff0c;直接对服务器进行测试 请求方式 pos…

微信小游戏5月畅销榜,新老产品更替显著,亿级爆款频出

小游戏由于微信的平台扶持&#xff0c;被视为可以大力发掘的蓝海&#xff0c;成为国内游戏最大的增长机会之一&#xff0c;随着越来越多的大厂和中小厂转向了小游戏赛道&#xff0c;每个月的小游戏畅销榜单都有不同变化。 5月的小游戏畅销榜显示&#xff0c;小游戏市场正经历显…

互联网宗教信息服务许可证怎么办理?

一、什么是互联网宗教信息 互联网宗教信息是指通过网站、应用程序、论坛、博客、微博、公众账号、即时通讯工具、网络直播等形式&#xff0c;以图文或音视频等方式传播有关宗教教义教规、宗教知识、宗教文化、宗教活动等涉及宗教的信息。 根据《互联网宗教信息服务管理办法》…

【 Python高级编程】Pythonz中Pandas表格读取与数据处理

Python中的Pandas表格读取与数据处理 Pandas 是 Python 中一个强大的数据处理与分析库&#xff0c;特别适合处理表格数据。本文将介绍如何使用 Pandas 读取表格文件并进行基本的数据处理操作。 一、读取表格数据 Pandas 可以读取多种格式的表格数据&#xff0c;常见的有 CSV…

Python深度学习:Bi-LSTM和LSTM在网络上有什么区别,对比来看

文章目录 LSTM代码解释类定义和构造函数前向传播方法 (`forward`)总结Bi-LSTMLSTM 代码 class BaseLSTMModel(nn.Module):def __init__(self, input_dim, hidden_dim, layer_dim, class_num):super().__init__

[BSidesCF 2020]Had a bad day1

看到页面有两个按钮 先随便点一个试一下&#xff0c;当我们点击之后发现url是有变动的 感觉url是有点东西的&#xff0c;可能是某种注入&#xff0c;先尝试一下sql注入&#xff0c;发现给出了报错 通过报错我们可以确定是文件包含漏洞&#xff0c;那我们试试php伪协议去读取一下…

保密工作应党而生、伴党而行、为党而兴

1.&#xff08;C &#xff09;工作应党而生、伴党而行、为党而兴&#xff0c;始终是党和国家的一项重要工作。 A. 农业 B. 国防 C. 保密 D. 文化 2.机关、单位对所产生的国家秘密事项&#xff0c;应当按照国家秘密及其密级的具体范围的规定确定密级&#xff0c;同时确定&#x…

JDBC操作数据库的方法

目录 一、JDBC介绍 二、使用方法&#xff08;以MySQL为例&#xff09; &#xff08;1&#xff09;MySQL的jar包&#xff0c;导入到IDEA &#xff08;2&#xff09;使用代码&#xff0c;操作数据库 1&#xff09;设置数据源 1.创建MysqlDataSource对象&#xff0c;使用set…

国产MCU芯片(2):东软MCU概览

前言: 国产芯片替代的一个主战场之一就是mcu,可以说很多国内芯片设计公司都打算或者已经在设计甚至有了一款或多款的量产产品了,这也是国际大背景决定的。过去的家电市场、过去的汽车电子市场,的确国产芯片的身影不是很常见,如今不同了,很多fabless投身这个行业,一种是…

【数据结构】排序(下)

个人主页~ 排序&#xff08;上&#xff09; 栈和队列 排序 二、常见排序的实现8、快速排序的优化9、非递归快速排序&#xff08;1&#xff09;基本思想&#xff08;2&#xff09;代码实现&#xff08;3&#xff09;时间复杂度&#xff08;4&#xff09;空间复杂度 10、归并排序…

一个基于大模型的多功能的本地网页语音合成工具

ChatTTS-ui 是一个开源项目&#xff0c;这是一个利用 ChatTTS 技术将文本转换为语音的本地网页界面工具。它不仅支持中英文和数字的混合输入&#xff0c;还提供了丰富的API接口&#xff0c;为开发者和用户提供了极大的便利。 项目地址&#xff1a;https://github.com/jianchang…

1.华为路由器-三层交换机-二层交换机组网连接

AR1配置GE 0/0/0接口IP [Huawei]int g0/0/0 [Huawei-GigabitEthernet0/0/0] [Huawei-GigabitEthernet0/0/0]ip add 1.1.1.1 24 [Huawei]iP route-static 192.168.0.0 16 1.1.1.2三层交换机配置如下 创建vlan [Huawei]vlan batch 10 20配置接口ip [Huawei]int g0/0/1 [Huawei…

git diff 命令

目录标题 [Q&A] git diff 作用常见用法比较工作目录与暂存区比较暂存区与最近一次提交比较工作目录与最近一次提交比较两个具体的提交之间差异 [Q&A] git diff 作用 git diff 用于展示不同版本之间文件内容的变化。 常见用法 比较工作目录与暂存区 显示工作目录中尚…

API接口设计的18条规范

API接口设计的18条规范 签名 目的&#xff1a;防止数据被篡改 实现方法&#xff1a; 接口请求方将请求参数、时间戳和密钥拼接成一个字符串使用MD5等hash算法生成签名sign在请求参数或请求头中增加sign参数&#xff0c;传递给API接口API接口网关服务验证传递的sign值&#…

数电逻辑门电路分析和Digital仿真

文章目录 1. 逻辑门电路 2. 非门&#xff08;NOT Gate&#xff09; 3. 与门&#xff08;AND Gate&#xff09; 4. 或门&#xff08;OR Gate&#xff09; 5. 与非门&#xff08;NAND Gate&#xff09; 6. 或非门&#xff08;NOR Gate&#xff09; 7. 异或门&#xff08;XO…

pinocchio计算MPC控制状态方程AB矩阵

pinocchio计算MPC控制状态方程AB矩阵 Pinocchio是一个用于机器人动力学和运动学计算的库,广泛应用于机器人控制和仿真中。为了在MPC控制中使用Pinocchio计算状态方程的线性化矩阵 A 和 B,需要以下步骤: 1、初始化机器人模型和数据结构: 使用Pinocchio加载机器人模型。初始…

开源模型应用落地-LangChain高阶-LCEL-表达式语言(七)

一、前言 尽管现在的大语言模型已经非常强大&#xff0c;可以解决许多问题&#xff0c;但在处理复杂情况时&#xff0c;仍然需要进行多个步骤或整合不同的流程才能达到最终的目标。然而&#xff0c;现在可以利用langchain来使得模型的应用变得更加直接和简单。 LCEL是什么&…