452. 用最少数量的箭引爆气球452. 用最少数量的箭引爆气球
题目链接
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/minimum-number-of-arrows-to-burst-balloons/
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
题目描述
题目分析
1.排序。
按照xstart 由小到大排序。
2.插入箭。
后一个的左<=前一个的右:更新待插入箭的最右位置。
后一个的左>前一个的右:后面的气球与前面的无重叠了,为前面的重叠的气球插入箭。
最后别忘了在res上加1,为最后一段重叠的气球插箭。
class Solution {
private:
static bool cmp(vector<int> a, vector<int> b){
return a[0] < b[0];
}
public:
int findMinArrowShots(vector<vector<int>>& points) {
int res = 0;
sort(points.begin(), points.end(), cmp);
for(int i = 1; i < points.size(); i++){
if(points[i - 1][1] >= points[i][0]){//不断更新points[i]
points[i][1] = min(points[i - 1][1], points[i][1]);
}else{
res++;
}
}
res++;
return res;
}
};