当前位置: 首页 > news >正文

LeetCode面试题Day7|LeetCode135 分发糖果、LeetCode42 接雨水

题目1:

指路:

. - 力扣(LeetCode)135 分发糖果

思路与分析:

给n个孩子按照评分给糖果,要求有二,其一为每个孩子最少有一颗糖果;其二为相邻孩子评分更高的糖果越多。那么在这里第一个条件没有异议,直接初始化一个结果数组初始化为n个1即可。那么接下来就是对比相邻孩子之间的评分并设置糖果值。在这里有一个需要思考的地方,拿给出的exampl1来讲,[1, 0, 2],对于左边两个孩子的评分来说,左1孩子评分比中间的孩子高,得到的糖果数也应该比中间的孩子多,而对于右边的两个孩子说,右边的孩子评分比中间的孩子高,得到的糖果数也应该比中间的孩子多。那么按照初始化为1的糖果数来看,最初三者糖果数皆为1,而左边孩子的糖果为2,右边孩子多一个也应该是2。那么总数就是5。那么再多几个孩子,例如[1, 2, 4, 3, 6, 5],首先,初始化的糖果集无异,[1, 1, 1, 1, 1, 1],那么因为(从左往右)第二个孩子的评分高于第一个,而第三个孩子的评分多于第二个,所以前三个孩子的糖果数应该是:第三个>第二个>第一个。而从第四个开始,因为其评分低于第三个,所以第四个孩子的糖果数理应少于第三个。那么这里就引发了左右不统一。接下来尝试解决左右不统一的问题。我们可以将评分分为两部分,左边>右边和右边大于左边,从前往后遍历时,当后者评分大于前者评分时,后者的糖果数也应该比前者的糖果数多一个(求的是最少的糖果数)。同样,从后往前当前者的评分大于后者评分时,这个孩子的糖果数为右边孩子的糖果数+1。当其顺序遍历得到的糖果数大于倒序遍历得到的糖果数时保留原糖果数。最后得到糖果集的总和即为最少需要准备的糖果数。

代码:

class Solution {
public:int candy(vector<int>& ratings) {int n = ratings.size();int ans = 0;vector<int> candies(n, 1);  // 最终糖果集for (int i = 1; i < n; i++) {if (ratings[i] > ratings[i - 1]) {  candies[i] = candies[i - 1] + 1;}}for (int i = n - 2; i >= 0; i--) {if (ratings[i] > ratings[i + 1]) {candies[i] = max(candies[i], candies[i + 1] + 1);}}for (int i = 0; i < n; i++) {ans += candies[i];}return ans;}
};

题目2:

指路:

. - 力扣(LeetCode)42 接雨水

思路与分析:

经典接雨水,那么我们讲接雨水的条件是两边的板高度大于中间,且短板效应接到的雨水高度以较低的板为主。那么首先要找出左边界的最大值和右边界的最大值。最后因为其宽度都为1,最正确的应该是长度乘宽度。

代码:

class Solution {
public:int trap(vector<int>& height) {int hsum = 0;int n = height.size();if (n == 0) return 0;vector<int> leftMax(n, 0);leftMax[0] = height[0];for (int i = 1; i < n; i++) {leftMax[i] = max(leftMax[i - 1], height[i]);}vector<int> rightMax(n, 0);rightMax[n - 1] = height[n - 1];for (int i = n - 2; i >= 0; i--) {rightMax[i] = max(rightMax[i + 1], height[i]);}for (int i = 0; i < n; i++) {hsum += min(leftMax[i], rightMax[i]) - height[i];}return hsum;}
};

http://www.lryc.cn/news/421075.html

相关文章:

  • [免费]适用于 Windows 10 的十大数据恢复软件
  • Win11+docker+vscode配置anomalib并训练自己的数据(3)
  • Java | Leetcode Java题解之第332题重新安排行程
  • 招聘公告|健安环保科技(广东)有限公司
  • 小程序的安全设计
  • 【Android】网络技术知识总结之WebView,HttpURLConnection,OKHttp,XML的pull解析方式
  • Kubernetes—k8s集群存储卷(pvc存储卷)
  • 用网格大师转换的3D Tiles数据,在进行了顶点重建后,尝试加载到Cesium中却无法显示内容。应该如何解决这一问题?
  • display:flex布局,最简单的案例
  • SQL注入实例(sqli-labs/less-17)
  • HTML+CSS+JS计算器
  • EasyCVR视频汇聚平台云计算技术核心优势:高效、灵活与可扩展性深度解读
  • JavaScript高阶笔记总结(Xmind格式):第一天
  • 十三、代理模式
  • Unity物理模块 之 2D效应器
  • 一款手机壳凭什么卖800元?Casetify品牌策略全解析 | 品牌出海
  • 【Rust光年纪】并发编程利器:探索 Rust 异步库与并行处理工具
  • 机器学习第一课
  • C语言典型例题32
  • 第二十五天学习笔记2024.8.9
  • sqlserver将一张表导出成txt
  • YOLOv8+DeepSort实现
  • 「链表」链表原地算法合集:原地翻转|原地删除|原地取中|原地查重 / LeetCode 206|237|2095|287(C++)
  • 【STM32】SPI通信和RTC实时时钟
  • DAMA学习笔记(十三)-大数据和数据科学
  • 【Java】Java 中的 toLowerCase() 方法详解
  • Linux: 进程概念详解
  • 【C++】模板详细讲解(含反向迭代器)
  • haproxy七层代理详解之-完整安装部署流程及负载均衡实现-及热更新方法
  • C++11 bind