博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
452 Minimum Number of Arrows to Burst Balloons 用最少数量的箭引爆气球
阅读量:5049 次
发布时间:2019-06-12

本文共 1147 字,大约阅读时间需要 3 分钟。

在二维空间中有许多球形的气球。对于每个气球,提供的输入是水平方向上,气球直径的开始和结束坐标。由于它是水平的,所以y坐标并不重要,因此只要知道开始和结束的x坐标就足够了。开始坐标总是小于结束坐标。平面内最多存在104个气球。

一支弓箭可以沿着x轴从不同点完全垂直地射出。在坐标x处射出一支箭,若有一个气球的直径的开始和结束坐标为 xstart,xend, 且满足  xstart ≤ x ≤ xend,则该气球会被引爆。可以射出的弓箭的数量没有限制。 弓箭一旦被射出之后,可以无限地前进。我们想找到使得所有气球全部被引爆,所需的弓箭的最小数量。
Example:
输入:
[[10,16], [2,8], [1,6], [7,12]]
输出:
2
解释:
对于该样例,我们可以在x = 6(射爆[2,8],[1,6]两个气球)和 x = 11(射爆另外两个气球)。
详见:https://leetcode.com/problems/minimum-number-of-arrows-to-burst-balloons/description/

C++:

class Solution {public:    int findMinArrowShots(vector
>& points) { if (points.empty()) { return 0; } sort(points.begin(), points.end()); int res = 1, end = points[0].second; for (int i = 1; i < points.size(); ++i) { if (points[i].first <= end) { end = min(end, points[i].second); } else { ++res; end = points[i].second; } } return res; }};

 参考:https://www.cnblogs.com/grandyang/p/6050562.html

转载于:https://www.cnblogs.com/xidian2014/p/8901239.html

你可能感兴趣的文章
wepy的使用
查看>>
转载:mysql数据库密码忘记找回方法
查看>>
scratch少儿编程第一季——06、人在江湖混,没有背景怎么行。
查看>>
面向对象1
查看>>
在ns2.35中添加myevalvid框架
查看>>
【贪心+DFS】D. Field expansion
查看>>
为什么要使用href=”javascript:void(0);”
查看>>
二进制文件的查看和编辑
查看>>
C# Async与Await的使用
查看>>
Mysql性能调优
查看>>
iOS基础-UIKit框架-多控制器管理-实例:qq界面框架
查看>>
javascript学习---BOM
查看>>
IOS-每个程序员的编程之路上都应该看这11本书
查看>>
自定义tabbar(纯代码)
查看>>
extjs fieldset 和 radio
查看>>
小程序底部导航栏
查看>>
Codeforces Gym101505G:Orchard Division(扫描线+线段树第k大)
查看>>
ibatis学习笔记
查看>>
18-ES6(1)
查看>>
poj1611 简单并查集
查看>>