先来看第一道:860. 柠檬水找零 - 力扣(LeetCode)

有如下三种情况:

  • 情况一:账单是5,直接收下。
  • 情况二:账单是10,消耗一个5,增加一个10
  • 情况三:账单是20,优先消耗一个10和一个5,如果不够,再消耗三个5

此时大家就发现 情况一,情况二,都是固定策略,都不用我们来做分析了,而唯一不确定的其实在情况三。

而情况三逻辑也不复杂甚至感觉纯模拟就可以了,其实情况三这里是有贪心的。

账单是20的情况,为什么要优先消耗一个10和一个5呢?

因为美元10只能给账单20找零,而美元5可以给账单10和账单20找零,美元5更万能!

所以局部最优:遇到账单20,优先消耗美元10,完成本次找零。全局最优:完成全部账单的找零。

局部最优可以推出全局最优,并找不出反例,那么就试试贪心算法!

C++代码如下:

class Solution {
public:bool lemonadeChange(vector<int>& bills) {int five = 0, ten = 0, twenty = 0;for (int bill : bills) {// 情况一if (bill == 5) five++;// 情况二if (bill == 10) {if (five <= 0) return false;ten++;five--;}// 情况三if (bill == 20) {// 优先消耗10美元,因为5美元的找零用处更大,能多留着就多留着if (five > 0 && ten > 0) {five--;ten--;twenty++; // 其实这行代码可以删了,因为记录20已经没有意义了,不会用20来找零} else if (five >= 3) {five -= 3;twenty++; // 同理,这行代码也可以删了} else return false;}}return true;}
};

然后看第二道:406. 根据身高重建队列 - 力扣(LeetCode)

按照身高排序之后,优先按身高高的people的k来插入,后序插入节点也不会影响前面已经插入的节点,最终按照k的规则完成了队列。

所以在按照身高从大到小排序后:

局部最优:优先按身高高的people的k来插入。插入操作过后的people满足队列属性

全局最优:最后都做完插入操作,整个队列满足题目队列属性

C++代码如下:

class Solution {
public:static bool cmp(const vector<int>& a, const vector<int>& b) {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++) {int position = people[i][1];que.insert(que.begin() + position, people[i]);}return que;}
};

然后看最后一道:452. 用最少数量的箭引爆气球 - 力扣(LeetCode)

这道题好像原来写过。

部分最优:当气球出现重叠,一起射,所用弓箭最少。全局最优:把所有气球射爆所用弓箭最少。

算法确定下来了,那么如何模拟气球射爆的过程呢?是在数组中移除元素还是做标记呢?

如果真实的模拟射气球的过程,应该射一个,气球数组就remove一个元素,这样最直观,毕竟气球被射了。

但仔细思考一下就发现:如果把气球排序之后,从前到后遍历气球,被射过的气球仅仅跳过就行了,没有必要让气球数组remove气球,只要记录一下箭的数量就可以了。

以上为思考过程,已经确定下来使用贪心了,那么开始解题。

为了让气球尽可能的重叠,需要对数组进行排序

那么按照气球起始位置排序,还是按照气球终止位置排序呢?

其实都可以!只不过对应的遍历顺序不同,我就按照气球的起始位置排序了。

既然按照起始位置排序,那么就从前向后遍历气球数组,靠左尽可能让气球重复。

从前向后遍历遇到重叠的气球了怎么办?

如果气球重叠了,重叠气球中右边边界的最小值 之前的区间一定需要一个弓箭

class Solution {
private:static bool cmp(const vector<int>& a, const vector<int>& b) {return a[0] < b[0];}
public:int findMinArrowShots(vector<vector<int>>& points) {if (points.size() == 0) return 0;sort(points.begin(), points.end(), cmp);int result = 1; // points 不为空至少需要一支箭for (int i = 1; i < points.size(); i++) {if (points[i][0] > points[i - 1][1]) {  // 气球i和气球i-1不挨着,注意这里不是>=result++; // 需要一支箭}else {  // 气球i和气球i-1挨着points[i][1] = min(points[i - 1][1], points[i][1]); // 更新重叠气球最小右边界}}return result;}
};

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/web/89994.shtml
繁体地址,请注明出处:http://hk.pswp.cn/web/89994.shtml
英文地址,请注明出处:http://en.pswp.cn/web/89994.shtml

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

接口自动化测试种涉及到接口依赖怎么办?

《接口自动化测试中接口依赖的处理方式及选择原则》在接口自动化测试中&#xff0c;接口依赖是指某个接口的请求参数、执行条件或测试结果依赖于其他接口的输出&#xff08;如返回数据、状态等&#xff09;。处理接口依赖是确保测试用例准确性和稳定性的关键&#xff0c;常见的…

hive分区表临时加载日批数据文件

源系统每日上传一个csv数据文件到数据中台指定目录&#xff0c;数据中台用hive表进行ETL工作。 先建一个外部分区表&#xff1a; create external table tmp_lease_contract ( contract_id string, vin string, amount float ) partitioned by (dt string) row format delim…

Python关于pandas的基础知识

一.扫盲&#xff08;一&#xff09;、pandas 是什么pandas 是 Python 的一个第三方数据处理库&#xff0c;它提供了高效、灵活的数据结构&#xff08;如 Series 和 DataFrame&#xff09;&#xff0c;能方便地对结构化数据进行清洗、转换、分析和处理。&#xff08;二&#xff…

React 英语单词补全游戏——一个寓教于乐的英语单词记忆游戏

预览&#xff1a;英语单词补全 &#x1f4d6; 产品概述 英语单词大冒险是一款专为 7-12 岁儿童设计的互动式英语学习游戏。通过听音频、补全单词的游戏方式&#xff0c;让孩子在轻松愉快的环境中提升英语词汇能力和听力水平。 &#x1f3af; 核心价值主张 寓教于乐: 将枯燥…

我的第一个开源项目 -- 实时语音识别工具

这是我的第一个开源项目&#xff0c;是我一直想做的一个小工具&#xff1a; 端到端实时语音转文字系统。 通过小程序和H5页面&#xff0c;用户可以实时采录音频&#xff0c;通过ws上传到java的netty server。 Java在经过权限验证、流量控制等操作之后&#xff0c;通过gRPC流…

AG32 mcu+cpld 联合编程(概念及流程)

在使用mcucpld联合编程之前&#xff0c;请确认已经熟练掌握mcu的使用方法&#xff0c;并且对cpld编程&#xff08;verilog语言&#xff09;有一定的基础。 另外&#xff0c;对AHB总线也需要有一定的了解。 这个章节分为两部分&#xff1a; 第一部分&#xff0c;展示联合编程…

Hadoop调度器深度解析:FairScheduler与CapacityScheduler的优化策略

Hadoop调度器概述在大数据处理的生态系统中&#xff0c;Hadoop作为分布式计算框架的核心&#xff0c;其资源调度机制直接决定了集群的吞吐效率和作业执行公平性。调度器作为Hadoop资源管理的中枢神经&#xff0c;通过协调计算资源与任务需求之间的动态平衡&#xff0c;成为支撑…

怎么自己搭建云手机

用闲置电脑搭建云手机 确保电脑安装 Ubuntu 20.04&#xff08;或其他支持Docker的Linux系统&#xff09;。 安装 Docker&#xff08;运行云手机的核心工具&#xff09;安装Redroid&#xff08;安卓容器&#xff09;运行安卓容器就欧克啦。 用云服务器搭建&#xff08;适合长…

网关:数据翻译、中转、协议转换与边缘计算

网关&#xff08;Gateway&#xff09;详解&#xff1a;翻译与中转站的核心作用 在计算机网络中&#xff0c;网关&#xff08;Gateway&#xff09;是一个非常重要的概念。它本质上是一个“翻译中转站”&#xff0c;其主要作用是将不同网络之间的数据进行“翻译”&#xff0c;并确…

UE5多人MOBA+GAS 番外篇:使用ECC(UGameplayEffectExecutionCalculation)制作伤害计算的流程

文章目录定义一些属性用于作为伤害基础还有获取要打出去的伤害创建一个ECC&#xff08;里面执行伤害的计算&#xff09;在执行ECC的GE之前需要修改ECC需要调用的值&#xff0c;也可以不改直接计算在属性中监听ECC输出的那个值然后处理扣血定义一些属性用于作为伤害基础还有获取…

SpringBoot实战0-5

接口文档&#xff1a;通俗的讲&#xff0c;接口文档能告诉开发者接口能返回的数据&#xff0c;以及为了获取这些数据&#xff0c;开发者需要输入什么样的数据&#xff0c;请求哪个接口&#xff08;即规范&#xff09;为什么使用接口文档&#xff1a;1、项目开发过程中前后端工程…

二、SpringBoot-REST开发

rest开发&#xff08;表现形式转换&#xff09;&#xff1a; 1、优点&#xff1a;隐藏访问资源的行为&#xff0c;无法通过地址得知对资源是何种操作&#xff0c;书写简化 2、GET查询 POST 新增/保存 PUT&#xff08;修改/更新&#xff09; DELETE&#xff08;删除&#xff09;…

大数据之路:阿里巴巴大数据实践——离线数据开发

数据开发平台 统一计算平台MaxCompute&#xff1a;主要服务于海量数据的存储和计算 &#xff0c;提供完善的数据导入方案&#xff0c; 以及多种经典的分布式计算模型&#xff0c;提供海量数据仓库的解决方案&#xff0c;能够更快速地解决用户的海量数据计算问题&#xff0c;有效…

我的网页聊天室设计

一、需求分析1.用户管理模块注册功能实现一个注册页面。注册页面上包含了一个输入框&#xff0c;输入用户名和密码. 注册成功后可以跳转到登录页面.登录功能实现一个登录页面。登录页面上包含一个输入框。输入用户名和密码. 登录成功后可以跳转到主页面.2.主界面用户信息左上角…

数据结构自学Days10 -- 二叉树的常用实现

✅ 一、为什么要学习二叉树&#xff1f; 1. &#x1f4e6; 组织数据的高效方式 二叉树可以快速插入、删除、查找数据&#xff0c;尤其在平衡时&#xff0c;时间复杂度为 $O(\log n)$。 适合表示分层结构&#xff08;如组织结构、文件系统、语法树&#xff09;。 2. &#x…

Java注解家族--`@ResponseBody`

ResponseBody ResponseBody是 Spring 框架中的一个注解&#xff0c;在基于 Spring 的 Web 开发中扮演着重要角色&#xff0c;以下是对它的详细总结&#xff1a; 1.定义与基本功能 定义&#xff1a;ResponseBody注解用于将 Controller 方法的返回值&#xff0c;通过适当的 HttpM…

react-window 大数据列表和表格数据渲染组件之虚拟滚动

简介 React Window 是一个高效的 React 组件库&#xff0c;专为渲染大数据列表和表格数据而设计。它通过”虚拟化”技术&#xff08;也称为”窗口化”或”列表虚拟化”&#xff09;解决了在 React 应用中渲染大量数据时的性能问题。与传统方法不同&#xff0c;React Window 只…

Eltable tree形式,序号列实现左对齐,并且每下一层都跟上一层的错位距离拉大

要的是如图所示效果序号加个class-name写样式然后给eltable加indent属性就可以了&#xff0c;我设置的25

FOC算法中SIMULINK一些常用模块(2)-Permanent Magnet Synchronous Machine模块

一&#xff0c;介绍这三个模块一起介绍了&#xff0c;由左到右&#xff0c;分别是电源模块&#xff0c;驱动模块和电机模块。主要介绍一下电机模块二&#xff0c;DC Voltage SourceDC Voltage Source 模块是用于表示直流电压源的基本组件&#xff0c;可以提供恒流直压&#xff…

RPG62.制作敌人攻击波数二:攻击ui

1。经典创建userwidget&#xff0c;使用xmbtextblock&#xff0c;结构如下。然后设置动画与音频&#xff0c;上下的参数是一样的&#xff0c;转到图表打开BP_SurvialGameMode2.再创建一个widget&#xff0c;结构如下新添的动画打开XMBGameModeBase&#xff0c;创建构造函数AXMB…