【代码随想录训练营】【Day35】第八章|贪心算法|860.柠檬水找零|406.根据身高重建队列|452. 用最少数量的箭引爆气球
创始人
2024-05-30 02:21:10
0

柠檬水找零

题目详细:LeetCode.860

一道非常简单的模拟题,根据题目要求编写程序即可:

Java解法(模拟):

class Solution {public boolean lemonadeChange(int[] bills) {int money_5 = 0, money_10 = 0;for(int b : bills){if(b == 5){money_5++;}else if(b == 10){money_10++;money_5--;}else if(b == 20){if(money_10 > 0){money_10--;money_5--;}else{money_5 -= 3;}}if(money_5 < 0 || money_10 < 0)return false;}return true;}
}

根据身高重建队列

题目详细:LeetCode.406

这道题与上一节的练习《分发糖果》有异曲同工之妙,当我们题目有两个维度时,如本题,有两个比较纬度身高h和数量k,所以看到这种题目一定要想先确定哪一个维度,再考虑能不能按照另一个维度重新排列得到正确结果,不能够两个维度条件同时考虑。

解题过程如下:

  • 先确定一个维度:我先按照身高h来排序,身高一定是从大到小排序(身高相同的话则k值较小的站前面),保证前面的节点一定都比当前节点高。
  • 再确定另一维度:
    • 局部最优解:身高从高到低依次按people的k值来插入列表,也就是将k值作为下标来执行插入操作,这样使得people插入后列表仍满足题目的排列要求
    • 全局最优解:全部元素都插入完成,整个队列仍满足题目的排列要求

注意:身高为什么一定是从大到小排?

  • 因为身高从小到大排序,后续完成插入后,结果无法满足题目的排列求,每个节点“前面正好有 k 个身高大于或等于 h 的人”的要求
  • 同理,如果这题要求为“前面正好有 k 个身高大于或等于 h 的人”,则先将身高从小到大排序

Java解法(先按身高排序,再按k值插入):

class Solution {public int[][] reconstructQueue(int[][] peoples) {// 按身高从大到小排序,身高相同则k值小的在前Arrays.sort(peoples, (a, b) -> {if(a[0] == b[0])return a[1] - b[1];return b[0] - a[0];});// 按照k值依次插入List ans = new ArrayList<>();for(int[] people : peoples){ans.add(people[1], people);}return ans.toArray(new int[peoples.length][]);}
}

用最少数量的箭引爆气球

题目详细:LeetCode.452

注意本题一个非常坑的测试数据:

[[-2147483646,-2147483645],[2147483646,2147483647]]

在对输入数据进行排序时,需要使用Integer内置的比较器,来防止输入数据溢出。

这道题的思路比较简单,但是我觉得我的表述可能不是很清晰,详细的题解可查阅:《代码随想录》— 用最少数量的箭引爆气球

Java解法(先排序,确定重叠的边界,进而确定箭的数量):

class Solution {public int findMinArrowShots(int[][] points) {Arrays.sort(points, (a, b) -> {// 不能使用 return a[0] - b[0];// 这里需要使用内置的比较器,防止数据溢出return Integer.compare(a[0], b[0]);});// points.length >= 1,所以至少会射出一支箭int count = 1; for(int i = 1; i < points.length; i++){if(points[i - 1][1] < points[i][0])// 如果当前气球的左边界和上一个气球的右边界没有交集// 则说明两个气球没有重叠,需要多射出一支箭count++;else// 如果当前气球的左边界和上一个气球的右边界存在交集// 则当前气球保留一个最小最右边界值,即与上一个气球重叠的最右边界值points[i][1] = Math.min(points[i][1], points[i - 1][1]);}return count;}
}

相关内容

热门资讯

安卓系统怎么调语言设置,And... 你有没有发现,手机里的文字突然变得陌生起来?是不是觉得安卓系统的语言设置有点让人摸不着头脑?别急,今...
安卓怎么换新系统,体验全新功能 亲爱的安卓用户们,是不是觉得你的手机越来越卡,功能也越来越跟不上潮流了呢?别急,今天就来教你怎么给安...
杂牌安卓平板电脑刷系统,解锁无... 你有没有想过,那些杂牌安卓平板电脑,虽然价格亲民,但有时候系统更新慢,功能也受限?别急,今天就来教你...
塞班系统游戏移植安卓,畅享新体... 你有没有想过,那些曾经陪伴我们度过无数欢乐时光的塞班系统游戏,现在竟然可以在安卓手机上继续畅玩?没错...
安卓只有一个系统,揭秘安卓系统... 你知道吗?在手机江湖里,安卓系统可是独树一帜的存在呢!它就像一位武林高手,凭借一己之力,在众多操作系...
软件包安卓系统,软件包的奥秘与... 你有没有发现,手机里的那些应用,就像是魔法一样,让我们的生活变得如此便捷?而这背后,离不开一个强大的...
怎么卸载安卓原生系统,安卓原生... 手机用久了,是不是觉得安卓原生系统有点卡?或者是想尝试一下全新的操作系统?别急,今天就来手把手教你如...
安卓办公系统推荐知乎,知乎推荐... 你有没有想过,在手机上办公也能这么高效?现在,我就要给你安利几个安卓办公系统,让你的手机变成一个小型...
安卓版本商超收银系统,高效管理... 你有没有想过,那些每天在商超里忙碌的收银员,他们手中的安卓版本收银系统,竟然是如此神奇的存在?今天,...
旧手机刷安卓tv系统,轻松打造... 你那台旧手机是不是已经闲置在角落里了?别让它默默无闻地度过余生,今天就来教你怎么给它来个华丽转身,让...
锁屏壁纸推荐安卓系统,安卓系统... 亲爱的手机控们,你是不是也和我一样,对锁屏壁纸有着超乎寻常的热爱?每天醒来,第一眼看到的便是那块小小...
安卓系统不使用sd卡,安卓系统... 你知道吗?最近在手机圈子里,有一个话题可是引起了不小的讨论呢!那就是安卓系统的新趋势——不再使用SD...
平板系统安卓版有哪些,功能丰富... 你有没有发现,现在的生活越来越离不开平板电脑了?无论是工作还是娱乐,平板电脑都成了我们生活中不可或缺...
安卓系统呼吸灯作用,探索安卓系... 你知道吗?你的安卓手机里有个神奇的小功能,它就像你的私人小秘书,时刻关注着你的生活节奏。没错,说的就...
安卓系统的设置停止,自动生成文... 亲爱的手机控们,你是否也有过这样的经历:手机里装了各种应用,可就是觉得运行速度越来越慢,有时候甚至卡...
魅动app安卓系统,安卓系统下... 你有没有发现,最近手机上多了一个叫“魅动app”的小家伙?它可是安卓系统里的一股清流,让人爱不释手。...
安卓怎么玩电脑系统,跨平台操作... 你是不是也和我一样,对安卓系统爱得深沉,但又想体验一下电脑系统的强大呢?别急,今天就来手把手教你如何...
安卓系统买什么品牌好用,盘点几... 你最近是不是在为选择一款好用的安卓手机而烦恼呢?市面上品牌繁多,让人眼花缭乱。别急,今天我就来给你详...
安卓系统怎样不卡顿,尽享丝滑体... 手机用久了是不是感觉越来越卡?别急,今天就来跟你聊聊安卓系统怎样不卡顿,让你的手机焕发新生!一、清理...
vidaa3是安卓系统,安卓系... 你有没有听说过Vidaa3这款智能电视?它可是最近在市场上掀起了一股热潮呢!你知道吗,Vidaa3搭...