【随想录】Day35—第八章 贪心算法 part04

devtools/2024/10/19 7:30:50/

目录

  • 题目1: 柠檬水找零
    • 1- 思路
    • 2- 题解
      • ⭐ 柠檬水找零 ——题解思路
  • 题目2: 406. 根据身高重建队列
    • 1- 思路
    • 2- 题解
      • ⭐ 根据身高重建队列 ——题解思路
  • 题目3: 用最少数量的箭引爆气球
    • 1- 思路
    • 2- 题解
      • ⭐ 用最少数量的箭引爆气球 ——题解思路


题目1: 柠檬水找零

  • 题目链接:435. 无重叠区间

1- 思路

贪心思路

  • 正向遍历数组,利用哈希表存储三个面额的钱的个数

2- 题解

⭐ 柠檬水找零 ——题解思路

在这里插入图片描述

class Solution {public boolean lemonadeChange(int[] bills) {int[] moneyCount = new int[3];for(int i = 0 ; i < bills.length;i++){if(bills[i]==5){moneyCount[0]++;}else if (bills[i]==10){moneyCount[1]++;moneyCount[0]--;}else if(bills[i]==20){if(moneyCount[1] > 0){moneyCount[1]--;moneyCount[0]--;}else{moneyCount[0]-=3;}}if(moneyCount[0]<0 || moneyCount[1]<0){return false;}}return true;}
}

题目2: 406. 根据身高重建队列

  • 题目链接:406. 根据身高重建队列

1- 思路

贪心思路

  • 1. 身高降序排:先根据身高进行降序排序,若身高相同,则 根据 前面有多少人升序排。
  • 2. 按照排序位置插入:构建 LinkedList ,根据排序位置,即 p[1] 进行插入

2- 题解

⭐ 根据身高重建队列 ——题解思路

在这里插入图片描述

class Solution {public int[][] reconstructQueue(int[][] people) {Arrays.sort(people,(o1,o2)->{if(o1[0]==o2[0]) return o1[1]-o2[1];return o2[0]-o1[0];});List<int[]> res = new LinkedList<>();for(int[] n:people){res.add(n[1],n);}return res.toArray(new int[res.size()][]);}
}

题目3: 用最少数量的箭引爆气球

  • 题目链接:452. 用最少数量的箭引爆气球

1- 思路

贪心思路

  • 先对数组根据左边界进行排序
  • for 循环遍历数组
    • ① 不重叠情况
    • ② 重叠情况
      • 将当前区间的右边界赋值为 当前遍历二者中最小的那个

遍历区间:

  • 1. 当前左边界大于前一个元素的右边界 (区间不重叠)
    • 需要对结果 res 加加
  • 2. 重叠判断
    • 若重叠,更新当前区间的右边界,使得当前区间的右边界为当前两个区间的最小值

2- 题解

⭐ 用最少数量的箭引爆气球 ——题解思路

在这里插入图片描述

class Solution {public int findMinArrowShots(int[][] points) {Arrays.sort(points,(o1,o2) -> Integer.compare(o1[0],o2[0]));int res = 1;for(int i = 1 ; i < points.length;i++){if(points[i-1][1] < points[i][0]){res++;}else{points[i][1] = Math.min(points[i-1][1],points[i][1]);}}return res;}
}


http://www.ppmy.cn/devtools/20674.html

相关文章

基于单片机公交语音报站系统设计 含源码,Proteus仿真原理图

资料下载地址&#xff1a;基于单片机公交语音报站系统设计 含源码,Proteus仿真原理图 1、前言 系统的总体设计需要充分运用STC单片机作为主控控制芯片&#xff0c;完成主控控制电路的基本设计&#xff0c;辅助控制电路是语音控制电路、12864显示电路、按键控制电路、…

Pytorch 的实际应用 学习笔记

一. 模型的下载 weights为false时则为没有提前经过训练的模型&#xff0c;为true时则经过了提前训练 vgg16_false torchvision.models.vgg16(weightsFalse) vgg16_true torchvision.models.vgg16(weightsTrue) 打印 二. 模型的修改 &#xff08;1&#xff09;添加操作 …

RAG开山之作:结合参数化与非参数化记忆的知识密集型NLP任务新解法

20年RAG刚提出时的论文&#xff1a;Retrieval-Augmented Generation for Knowledge-Intensive NLP Tasks&#xff0c;也算是RAG的开山之作之一了。 摘要&#xff1a;检索增强生成&#xff08;RAG&#xff09;方法结合了预训练语言模型与基于检索的非参数化记忆&#xff0c;通过…

Flink 实时数仓(二)【ODS 层开发】

前言 最近投了不少的实习&#xff0c;也收到不错的反馈&#xff0c;虽然是中小公司偏多&#xff0c;但是毕竟现在这个环境双非进大厂实习可不同当年了。可惜的是学院不放人&#xff0c;无奈啊&#xff0c;遍身罗绮者&#xff0c;不是养蚕人。我累死累活肝了两年了&#xff0c;好…

cnpm安装

npm install -g cnpm --registryhttps://registry.npmmirror.com # 注册模块镜像 npm set registry https://registry.npmmirror.com // node-gyp 编译依赖的 node 源码镜像 npm set disturl https://npmmirror.com/dist // 清空缓存 npm cache clean --force // 安装c…

基于YOLOV8+Pyqt5无人机航拍太阳能电池板检测系统

1.YOLOv8的基本原理 YOLOv8是一种前沿的目标检测技术&#xff0c;它基于先前YOLO版本在目标检测任务上的成功&#xff0c;进一步提升了性能和灵活性&#xff0c;在精度和速度方面都具有尖端性能。在之前YOLO 版本的基础上&#xff0c;YOLOv8 引入了新的功能和优化&#xff0c;…

【展会邀请】百华鞋业邀您参加2024山东省休闲旅游产业展!

2024山东省休闲旅游产业展将于4月25日—27日在临沂国际博览中心精彩亮相。本届展会由山东省旅游行业协会、山东省文化产业发展协会主办&#xff0c;山东新琅琊投资发展集团有限公司承办的2024休闲旅游产业展&#xff0c;将在临沂国际博览中心精彩亮相。山东百华鞋业将作为临沂户…

c++11 标准模板(STL)本地化库 - 平面类别(time_get) - 从输入字符序列中解析时间/日期值到 std::tm 中(一)

本地化库 本地环境设施包含字符分类和字符串校对、数值、货币及日期/时间格式化和分析&#xff0c;以及消息取得的国际化支持。本地环境设置控制流 I/O 、正则表达式库和 C 标准库的其他组件的行为。 平面类别 从输入字符序列中解析时间/日期值到 std::tm 中 std::time_get …