2025-3-12 leetcode刷题情况(贪心算法--区间问题)

embedded/2025/3/15 18:52:07/

一、452.用最少数量的箭引爆气球

1.题目描述

2.代码

3.思路

使用 Arrays.sort 方法对 points 数组按照气球的起始坐标进行排序。这里使用 Integer.compare(a[0], b[0]) 作为比较器,确保气球按起始坐标从小到大排列。将箭的数量 count 初始化为 1,因为至少需要一支箭来开始引爆气球。

从第二个气球开始遍历,对于每个气球 points[i]:如果当前气球的起始坐标 points[i][0] 大于前一个气球的结束坐标 points[i - 1][1],说明这两个气球不重叠,需要额外一支箭来引爆当前气球,因此 count 加 1。如果当前气球和前一个气球重叠,更新当前气球的结束坐标为当前气球和前一个气球结束坐标的最小值,即 points[i][1] = Math.min(points[i][1], points[i - 1][1])。这样做是为了保证后续判断时,能正确处理重叠气球的范围。

遍历结束后,count 即为引爆所有气球所需的最少箭数。

二、435.无重叠区间

1.题目描述

2.代码

3.思路

使用 Arrays.sort 方法对 intervals 数组按照区间的起始位置进行排序。

通过 Integer.compare(a[0], b[0]) 作为比较器,确保区间按起始位置从小到大排列。

将不重叠区间的数量 count 初始化为 1,因为至少有一个区间可以保留。

从第二个区间开始遍历,对于每个区间 intervals[i]:若当前区间的起始位置 intervals[i][0] 小于前一个区间的结束位置 intervals[i - 1][1],说明这两个区间重叠。

此时,将当前区间的结束位置更新为当前区间和前一个区间结束位置的最小值,即 intervals[i][1] = Math.min(intervals[i - 1][1], intervals[i][1]),然后跳过本次循环继续处理下一个区间。若当前区间与前一个区间不重叠,说明找到了一个新的不重叠区间,将 count 加 1。

用区间的总数 intervals.length 减去不重叠区间的数量 count,得到需要移除的最少区间数量并返回。


http://www.ppmy.cn/embedded/172837.html

相关文章

MCU的工作原理:嵌入式系统的控制核心

MCU的工作原理可以概括为以下几个步骤: 1. 初始化 上电后,MCU从Flash存储器中加载程序代码,并初始化外设和寄存器。 2. 任务执行 根据程序逻辑,MCU执行数据处理、外设控制和通信等任务。通过中断系统实时响应外部事件。 3. 低…

postgresql源码安装

步骤 1: 安装依赖 在开始之前,请确保您的系统上安装了编译 PostgreSQL 所需的依赖包。使用以下命令安装必要的软件包: 对于 Debian/Ubuntu 系统: sudo apt update sudo apt install build-essential libreadline-dev zlib1g-dev flex biso…

L2-4 吉利矩阵

输入样例: 7 3输出样例: 666 这道题是暴力纯搜,但是很难想,我这个是看的别人的代码 #include "bits/stdc.h" using namespace std; int x[20][20]; int l, n; int cnt 0; int sumx[5], sumy[5]; void dfs(int x, in…

TypeScript 高级类型 vs JavaScript:用“杂交水稻”理解类型编程

如果把 JavaScript 比作乐高积木,TypeScript 就是一套智能积木系统。本文将用最生活化的比喻,带你理解 TypeScript 那些看似复杂的高级类型。 一、先看痛点:JavaScript 的“薛定谔类型” // 场景:用户信息处理 function getUserI…

十五、Vue 与 Webpack 5:优化构建性能的实用技巧

在现代前端开发中,构建性能是影响开发效率和用户体验的关键因素之一。Webpack 5 作为目前最流行的构建工具之一,提供了许多强大的功能来优化构建性能。本文将深入探讨如何通过 Webpack 5 优化 Vue 项目的构建性能,并结合实际示例讲解实用技巧。 1. Webpack 5 的新特性 1.1 …

Java8的新特性

1.Lambda表达式和函数式接口 Lambda的基础:函数式接口 Java 8与之前版本的区别: Java 7及之前:接口中只能包含抽象方法,无法通过函数式接口简洁地表示Lambda表达式。Java 8:通过FunctionalInterface注解,明…

WPF可编辑的DataGrid根据条件控制最后一行的按钮显示隐藏

目录 页面代码后台代码动态生成按钮主要代码&#xff1a; 如下图&#xff0c;可编辑的DataGrid&#xff0c;如果有操作按钮&#xff0c;则最后一行会异常出现按钮&#xff1b;解决办法就是让代码动态生成按钮&#xff1b; 页面代码 <Page x:Class"WpfSnqkGasAnalysi…

C++【类和对象】(超详细!!!)

C【类和对象】 1.运算符重载2.赋值运算符重载3.日期类的实现 1.运算符重载 (1).C规定类类型运算符使用时&#xff0c;必须转换成调用运算符重载。 (2).运算符重载是具有特殊名字的函数&#xff0c;名字等于operator加需要使用的运算符&#xff0c;具有返回类型和参数列表及函数…