代码随想录算法训练营第三十五 | ● 860.柠檬水找零 ● 406.根据身高重建队列 ● 452. 用最少数量的箭引爆气球

本文主要是介绍代码随想录算法训练营第三十五 | ● 860.柠檬水找零 ● 406.根据身高重建队列 ● 452. 用最少数量的箭引爆气球,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

860.柠檬水找零

讲解链接:https://programmercarl.com/0860.%E6%9F%A0%E6%AA%AC%E6%B0%B4%E6%89%BE%E9%9B%B6.html

本题只有5元10元20元,只需要考虑收到5、10、20这三种情况;
收到5元,五块的个数++;
收到10,找5元---->判断5元的数量够不够找 => 只需要记录5元的个数;同时把10元的个数加一
收到20,找15:10 *1+ 5 * 1 或者 5 * 3;同理

class Solution {
public:bool lemonadeChange(vector<int>& bills) {int num_10 = 0;int num_5 = 0;int num_20 = 0;for(int i=0;i<bills.size();i++) {if(bills[i]==5)num_5++;if(bills[i]==10) {if(num_5>=1) {num_10++;num_5--;}elsereturn false;}if(bills[i]==20) {if(num_10>=1 && num_5>=1) {num_20++;num_10--;num_5--;}else if(num_5>=3) {num_5-=3;num_20++;}elsereturn false;}}return true;}
};

**406.根据身高重建队列 **

讲解链接:https://programmercarl.com/0406.%E6%A0%B9%E6%8D%AE%E8%BA%AB%E9%AB%98%E9%87%8D%E5%BB%BA%E9%98%9F%E5%88%97.html

思路:
1)根据身高从大到小排序(借助sort 利用cmp函数定义排序规则),身高相同时看k[i]小的在前,( 题中cmp()函数定义的时候要用static)
(二维数组传入cmp的参数是从中取出的数组,相当于[ [], [], [] ]取出[] ,这里的表示自己给搞复杂了)
2)定义一个新的二维数组,不在原先数据上进行操作
3)排好序后,只剩下往空白二维数组中插入了,根据k[i]的值确定插入位置

class Solution {
public:// 从二维数组中取出两个人的数据(表示为数组a 数组b)//定义为static类型static bool cmp(const vector<int>& a, const vector<int>& b) {//按身高升序进行排序,如果相同,k小的放前面if(a[0] == b[0]) return a[1]<b[1];return a[0]>b[0];}vector<vector<int>> reconstructQueue(vector<vector<int>>& people) {//按身高进行排序sort(people.begin(),people.end(),cmp);//二维数组保存结果vector<vector<int>> que; for(int i=0;i<people.size();i++) {//排好序之后,按照k值int position = people[i][1];que.insert(que.begin() + position, people[i]);}return que;}
};

在这里插入图片描述

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

讲解链接:https://programmercarl.com/0452.%E7%94%A8%E6%9C%80%E5%B0%91%E6%95%B0%E9%87%8F%E7%9A%84%E7%AE%AD%E5%BC%95%E7%88%86%E6%B0%94%E7%90%83.html
思路:
1.按起始坐标进行排序
2.从第二个气球开始,判断i(当前气球)是否与i-1(上一个气球)有交际:
若第二个气球 与 第一个坐标区间没有交集——2左界>1右界
if(points[i][0]>points[i-1][1])
3.如有交集,射箭数加一
4.更新i的右边界为交集区域的右边界(最小右边界)

class Solution {
public:static bool cmp(const vector<int>&a, const vector<int>&b) {//从坐标左侧小值开始,所以是升序return a[0]<b[0];}int findMinArrowShots(vector<vector<int>>& points) {if(points.size()==0)return 0;//按起始坐标  升序排序sort(points.begin(),points.end(),cmp);//记录需要射几箭int result = 1;for(int i=1;i<points.size();i++) {//若第二个气球 与 第一个坐标区间没有交集——2左界>1右界if(points[i][0]>points[i-1][1])result++;else {//把i的右界,更新为最小右边界points[i][1] = min(points[i-1][1],points[i][1]);}}return result;}
};

在这里插入图片描述

这篇关于代码随想录算法训练营第三十五 | ● 860.柠檬水找零 ● 406.根据身高重建队列 ● 452. 用最少数量的箭引爆气球的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1022551

相关文章

深入理解Mysql OnlineDDL的算法

《深入理解MysqlOnlineDDL的算法》本文主要介绍了讲解MysqlOnlineDDL的算法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小... 目录一、Online DDL 是什么?二、Online DDL 的三种主要算法2.1COPY(复制法)

Java集合之Iterator迭代器实现代码解析

《Java集合之Iterator迭代器实现代码解析》迭代器Iterator是Java集合框架中的一个核心接口,位于java.util包下,它定义了一种标准的元素访问机制,为各种集合类型提供了一种统一的... 目录一、什么是Iterator二、Iterator的核心方法三、基本使用示例四、Iterator的工

Java 线程池+分布式实现代码

《Java线程池+分布式实现代码》在Java开发中,池通过预先创建并管理一定数量的资源,避免频繁创建和销毁资源带来的性能开销,从而提高系统效率,:本文主要介绍Java线程池+分布式实现代码,需要... 目录1. 线程池1.1 自定义线程池实现1.1.1 线程池核心1.1.2 代码示例1.2 总结流程2. J

JS纯前端实现浏览器语音播报、朗读功能的完整代码

《JS纯前端实现浏览器语音播报、朗读功能的完整代码》在现代互联网的发展中,语音技术正逐渐成为改变用户体验的重要一环,下面:本文主要介绍JS纯前端实现浏览器语音播报、朗读功能的相关资料,文中通过代码... 目录一、朗读单条文本:① 语音自选参数,按钮控制语音:② 效果图:二、朗读多条文本:① 语音有默认值:②

Vue实现路由守卫的示例代码

《Vue实现路由守卫的示例代码》Vue路由守卫是控制页面导航的钩子函数,主要用于鉴权、数据预加载等场景,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着... 目录一、概念二、类型三、实战一、概念路由守卫(Navigation Guards)本质上就是 在路

uni-app小程序项目中实现前端图片压缩实现方式(附详细代码)

《uni-app小程序项目中实现前端图片压缩实现方式(附详细代码)》在uni-app开发中,文件上传和图片处理是很常见的需求,但也经常会遇到各种问题,下面:本文主要介绍uni-app小程序项目中实... 目录方式一:使用<canvas>实现图片压缩(推荐,兼容性好)示例代码(小程序平台):方式二:使用uni

JAVA实现Token自动续期机制的示例代码

《JAVA实现Token自动续期机制的示例代码》本文主要介绍了JAVA实现Token自动续期机制的示例代码,通过动态调整会话生命周期平衡安全性与用户体验,解决固定有效期Token带来的风险与不便,感兴... 目录1. 固定有效期Token的内在局限性2. 自动续期机制:兼顾安全与体验的解决方案3. 总结PS

C#中通过Response.Headers设置自定义参数的代码示例

《C#中通过Response.Headers设置自定义参数的代码示例》:本文主要介绍C#中通过Response.Headers设置自定义响应头的方法,涵盖基础添加、安全校验、生产实践及调试技巧,强... 目录一、基础设置方法1. 直接添加自定义头2. 批量设置模式二、高级配置技巧1. 安全校验机制2. 类型

Python屏幕抓取和录制的详细代码示例

《Python屏幕抓取和录制的详细代码示例》随着现代计算机性能的提高和网络速度的加快,越来越多的用户需要对他们的屏幕进行录制,:本文主要介绍Python屏幕抓取和录制的相关资料,需要的朋友可以参考... 目录一、常用 python 屏幕抓取库二、pyautogui 截屏示例三、mss 高性能截图四、Pill

使用MapStruct实现Java对象映射的示例代码

《使用MapStruct实现Java对象映射的示例代码》本文主要介绍了使用MapStruct实现Java对象映射的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,... 目录一、什么是 MapStruct?二、实战演练:三步集成 MapStruct第一步:添加 Mave