★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★
➤微信公众号:山青咏芝(shanqingyongzhi)
➤博客园地址:山青咏芝(https://www.cnblogs.com/strengthen/)
➤GitHub地址:https://github.com/strengthen/LeetCode
➤原文地址:https://www.cnblogs.com/strengthen/p/10342073.html 
➤如果链接不是山青咏芝的博客园地址,则可能是爬取作者的文章。
➤原文已修改更新!强烈建议点击原文地址阅读!支持作者!支持原创!
★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★

There are a number of spherical balloons spread in two-dimensional space. For each balloon, provided input is the start and end coordinates of the horizontal diameter. Since it's horizontal, y-coordinates don't matter and hence the x-coordinates of start and end of the diameter suffice. Start is always smaller than end. There will be at most 104 balloons.

An arrow can be shot up exactly vertically from different points along the x-axis. A balloon with xstart and xend bursts by an arrow shot at x if xstart ≤ x ≤ xend. There is no limit to the number of arrows that can be shot. An arrow once shot keeps travelling up infinitely. The problem is to find the minimum number of arrows that must be shot to burst all balloons.

Example:

Input:
[[10,16], [2,8], [1,6], [7,12]]Output:
2Explanation:
One way is to shoot one arrow for example at x = 6 (bursting the balloons [2,8] and [1,6]) and another arrow at x = 11 (bursting the other two balloons).

在二维空间中有许多球形的气球。对于每个气球,提供的输入是水平方向上,气球直径的开始和结束坐标。由于它是水平的,所以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(射爆另外两个气球)。

744ms
 1 class Solution {
 2     func findMinArrowShots(_ points: [[Int]]) -> Int {
 3         var points = points
 4         if points.isEmpty {return 0}
 5         points.sort(by: {(_ a:[Int],_ b:[Int]) -> Bool in return a[1] < b[1]})
 6         var res:Int = 1
 7         var end:Int = points[0][1]
 8         for i in 1..<points.count
 9         {
10             if points[i][0] <= end
11             {
12                 end = min(end, points[i][1])
13             }
14             else
15             {
16                 res += 1
17                 end = points[i][1]
18             }
19         }
20         return res
21     }
22 }

转载于:https://www.cnblogs.com/strengthen/p/10342073.html

[Swift]LeetCode452. 用最少数量的箭引爆气球 | Minimum Number of Arrows to Burst Balloons相关推荐

  1. leetcode-452 用最少数量的箭引爆气球

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

  2. leetcode452. 用最少数量的箭引爆气球

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

  3. 贪心法—LeetCode 452 用最少数量的箭引爆气球

    用最少数量的箭引爆气球 题目: 在二维空间中有许多球形的气球.对于每个气球,提供的输入是水平方向上,气球直径的开始和结束坐标.由于它是水平的,所以y坐标并不重要,因此只要知道开始和结束的x坐标就足够了 ...

  4. c语言贪心算法合并箭,贪心算法:用最少数量的箭引爆气球

    ❝ 通知:一些录友表示经常看不到每天上午的文章,现在公众号已经不按照发送时间推荐了,而是根据一些规则乱序推送,所以可能关注了「代码随想录」也一直看不到文章,建议把「代码随想录」设置星标哈,设置星标之后 ...

  5. Suzy想吃烤蛋挞了Day35 | 贪心算法进行时:860. 柠檬水找零,406. 根据身高重建队列,452. 用最少数量的箭引爆气球

    860. 柠檬水找零 solution 不要漏掉的一种情况是:如果收到了20,可以找10+5,或者5+5+5 class Solution:def lemonadeChange(self, bills ...

  6. 2021.05.20最少数量的箭引爆气球

    2021.05.20最少数量的箭引爆气球 题目描述 在二维空间中有许多球形的气球.对于每个气球,提供的输入是水平方向上,气球直径的开始和结束坐标.由于它是水平的,所以纵坐标并不重要,因此只要知道开始和 ...

  7. 代码随想录35——贪心:860柠檬水找零、406根据身高重建队列、452用最少数量的箭引爆气球

    文章目录 1.860柠檬水找零 1.1.题目 1.2.解答 2.406根据身高重建队列 2.1.题目 2.2.解答 3.452用最少数量的箭引爆气球 3.1.题目 3.2.解答 1.860柠檬水找零 ...

  8. 力扣记录:贪心算法3较难(1)区间问题——55 跳跃游戏,45 跳跃游戏II,452 用最少数量的箭引爆气球,435 无重叠区间,763 划分字母区间,56 合并区间

    本次题目 55 跳跃游戏 45 跳跃游戏II 452 用最少数量的箭引爆气球 435 无重叠区间 763 划分字母区间 56 合并区间 55 跳跃游戏 局部最优:不管每次跳多少步,取最大跳跃步数,若覆 ...

  9. Java实现 LeetCode 452 用最少数量的箭引爆气球

    452. 用最少数量的箭引爆气球 在二维空间中有许多球形的气球.对于每个气球,提供的输入是水平方向上,气球直径的开始和结束坐标.由于它是水平的,所以y坐标并不重要,因此只要知道开始和结束的x坐标就足够 ...

  10. 用最少数量的箭引爆气球(Java)

    452. 用最少数量的箭引爆气球 有一些球形气球贴在一堵用 XY 平面表示的墙面上.墙面上的气球记录在整数数组 points ,其中points[i] = [xstart, xend] 表示水平直径在 ...

最新文章

  1. Linux下gdb调试工具的使用
  2. Android移动开发之【Android实战项目】DAY9-LineChart的使用
  3. tableau可视化数据分析60讲(二十二)-tableau常见面试题目
  4. 对Spring IOC的理解(转)
  5. 尺度空间(Scale space)理论
  6. P1314,jzoj3028-聪明的质监员【二分答案,前缀和】
  7. [css] 使用css将图片转换成黑白的效果
  8. Android中ActionBar中不显示overflow(就是三个点的那个按钮)解决办法
  9. 解决mysql分页数据错乱问题
  10. 随机数-random模块
  11. excel部分快捷键
  12. 垃圾短信分类java_有了这个神器,快速告别垃圾短信邮件
  13. 数据库:概念结构设计
  14. 代码随想录第二天 leetcode 977、209、59
  15. vue生成自定义二维码样式
  16. OrCAD+PADS联合绘制PCB的总结
  17. C/C++使用Quirc库解析二维码(QRcode)
  18. kettle安装与配置
  19. 百度测试工程师胜任力模型
  20. Windows Linux 相同功能软件对应列表(转)

热门文章

  1. ASP.net 2.0 的 Membership Provider 与 Role Provider 第一部分——引进资源
  2. 提升效率小工具,我用30分钟就干完一天的活
  3. mysql4ge表联表查询_【MySQL】MariaDB10.2新特性--Flashback
  4. 数据之路 - Python爬虫 - Json模块与JsonPath
  5. English vocabulary-1
  6. jQuery-EasyUI
  7. spring中for循环中事务
  8. GitHub C 和 C++ 开源库的清单(含示例代码)
  9. 父子进程共享内存通信的三种方法
  10. 2017年11月11日