- 两道题不同的问法,但是具有相同的解题思路
leetcode452:用最少数量的箭引爆气球
-
题目:
-
有一些球形气球贴在一堵用 XY 平面表示的墙面上。墙面上的气球记录在整数数组 points ,其中points[i] = [xstart, xend] 表示水平直径在 xstart 和 xend之间的气球。你不知道气球的确切 y 坐标。
一支弓箭可以沿着 x 轴从不同点 完全垂直 地射出。在坐标 x 处射出一支箭,若有一个气球的直径的开始和结束坐标为 xstart,xend, 且满足 xstart ≤ x ≤ xend,则该气球会被 引爆 。可以射出的弓箭的数量 没有限制 。 弓箭一旦被射出之后,可以无限地前进。
给你一个数组 points ,返回引爆所有气球所必须射出的 最小 弓箭数 。
-
-
思路:贪心算法
-
代码如下:
class Solution {
public int findMinArrowShots(int[][] points) {
if(points.length == 0 ){
return 0;
}
int res = 1;
Arrays.sort( points,(o1,o2)-> Integer.compare(o1[0],o2[0]));
int n = points.length;
for(int i = 1; i < n; i++){
//如果相邻的两个气球 存在 空隙;说明需要多射一支箭
if(points[i][0] > points[i-1][1]){
res++;
}else{
//相邻的两个气球 不存在 空隙,取相邻的两个气球右边界最小的一个(贪心算法)
points[i][1] = Math.min(points[i][1],points[i-1][1]);
}
}
return res;
}
}
leetcode435:无重叠区间
- 题目:
- 给定一个区间的集合 intervals ,其中 intervals[i] = [starti, endi] 。返回 需要移除区间的最小数量,使剩余区间互不重叠 。
- 思路:贪心算法+代码注释
- 代码如下:
class Solution {
public int eraseOverlapIntervals(int[][] intervals) {
int n = intervals.length;
int remove = 0;
Arrays.sort(intervals,(o1,o2) -> Integer.compare(o1[0],o2[0]));
int pre = intervals[0][1];
for(int i = 1; i<n;i++){
//如果前一个区间右边界 大于 当前区间的左边界 说明重叠,remove数量+1
if(pre > intervals[i][0]){
remove++;
//贪心算法更新前一个区间右边界
pre = Math.min(pre,intervals[i][1]);
}else{
//前一个区间右边界 小于等于 当前区间的左边界;更新区间右边界
pre = intervals[i][1];
}
}
return remove;
}
}