代码随想录算法训练营:29/60

非科班学习算法day29 | LeetCode134:加油站 ,Leetcode135:分发糖果 ,Leetcode860:柠檬水找零 


介绍

包含LC的两道题目,还有相应概念的补充。

相关图解和更多版本:

代码随想录 (programmercarl.com)https://programmercarl.com/#%E6%9C%AC%E7%AB%99%E8%83%8C%E6%99%AF


  

一、LeetCode题目

1.LeetCode134:加油站 

题目链接:134. 加油站 - 力扣(LeetCode)

题目解析

       这里很容易被示例的做法干扰,实际上,我们需要的就是别对两个数组,到达一个位置(i)对应的需要加上gas(i)减去cost(i),这就我们需要比对的。这里先说一种之前有局限性的思路,先对两个数组相减,构造新的数组,如果数组元素为负数表示到达不了下一位,那么继续遍历,找到第一个不为负数的位置为初始位置,并且控制总和为负数的话返回-1,这样的做法最大的问题就在于我没有意识到,加油的过程也是需要一个初始量累计的,所以我不能单纯比较一个位置为负数就跳过这个位置,而应该是用cur变量维护start的位置,如果cur在累加的过程中变为负数,那么就重置cur并且将返回的start向后加一位。

 c++代码如下:

class Solution {
public://gas是加的,cost是减的//建立差值数组,如果数组和是负数,那么不可能有解,如果大于等于则有唯一解int canCompleteCircuit(vector<int>& gas, vector<int>& cost) {int tolsum = 0;int cursum = 0;int start = 0;vector<int> nd = vector<int>(gas.size(),0);for(int i = 0; i<gas.size();i++){nd[i] = gas[i] - cost[i];tolsum+=nd[i];cursum+=nd[i];if(cursum<0){start = i+1;cursum = 0;}}if(tolsum<0) return -1;return start;}
};

注意点1:这里可能会疑惑start超出最后一位怎么办,实际上,当cur超出最后一位的时候,并没有影响,不会访问空指针;而且关于最后的返回有tolsum控制,如果start超出,直接就返回-1了。注意!这里整个循环已经完成了一轮遍历,只不过遍历是从头到尾的。

 2.Leetcode135:分发糖果 

题目链接:135. 分发糖果 - 力扣(LeetCode)

题目解析

       第一次做就是中了圈套,总想一次就确定好糖果的数量,这就导致条件特别多,很容易混乱,这里就使用了一种非常常用的方法,两个方向分别遍历,去比较一个元素的左边和右边元素的关系,同时维护糖果数组,这样就可以实时更正。

        这里有一个问题就是为什么需要两个方向,因为在比较右边元素的时候,和左边一样,有一个累计的过程,如果从左边遍历比较右边的元素,就没法实时更新下一个元素的信息。

 C++代码如下: 

class Solution {
public:// 不能顾此失彼,分为两边去比对孩子int candy(vector<int>& ratings) {// 创建需要维护的糖果数组vector<int> candys = vector<int>(ratings.size(), 1);// 想象排队过程,先和左边的孩子比是大是小for (int i = 1; i < ratings.size(); ++i) {// 维护数组// 左边小-加糖果if (ratings[i] > ratings[i - 1]) {candys[i] = candys[i - 1] + 1;}// 左边大-重置糖果else {candys[i] = 1;}}// 比对右边孩子是大是小for (int i = ratings.size() - 2; i >= 0; --i) {// 在之前的基础上维护数组// 右边小-加糖果if (ratings[i + 1] < ratings[i]) {candys[i] = max(candys[i], candys[i + 1] + 1);}// 右边大-无需操作}// 累计糖果int sum = 0;for (int i = 0; i < candys.size(); ++i) {sum += candys[i];}return sum;}
};

注意点1:这里初始化,将糖果数组全部初始化为1,因为题目要求孩子的最少糖果数是1。所以在左边遍历的过程中,遇到需要重置的糖果,也可以不写这个命令,因为已经做好了初始化。

注意点2:第二遍为什么右边大不需要维护数组,可以举一个数组作为例子,当前其实也是重置了糖果数量为1,但是要和之前的糖果数取一个大值,那么不就是当前的糖果数么,所以不需要处理。 

3.Leetcode860:柠檬水找零

题目链接:860. 柠檬水找零 - 力扣(LeetCode)

题目解析

       终于在贪心遇到一道爽题,这道题其实也就是模拟生活中找零的行为,但是需要注意的就是可能找不开零!那么我们的贪心策略就是尽可能找大的零(10)把灵活的5留着去找10的零,或者没有10的时候去找20的零。策略有了,就需要变量维护当前的钱的数量,这里没有维护20,因为20并不用于找零,只是作为判断条件来做找零行为。

C++代码如下:

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

总结


打卡第29天,坚持!!!

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

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

相关文章

IT专业高考假期入门指南

IT领域预习指南&#xff1a;开启未来科技之旅 一、确定兴趣方向 IT领域广阔&#xff0c;涵盖软件开发、网络安全、数据分析、人工智能等多个方向。首先&#xff0c;明确自己的兴趣所在&#xff0c;这将决定你后续学习的重点。比如&#xff0c;如果你对构建应用程序感兴趣&…

【1.3】动态规划-解码方法

一、题目 一条包含字母A-Z的消息通过以下映射进行了编码&#xff1a; A -> 1 B -> 2 ... Z -> 26 要解码已编码的消息&#xff0c;所有数字必须基于上述映射的方法&#xff0c;反向映射回字母&…

新能源汽车充电站远程监控系统S275钡铼技术无线RTU

新能源汽车充电站的远程监控系统在现代城市基础设施中扮演着至关重要的角色&#xff0c;而钡铼技术的S275无线RTU作为一款先进的物联网数据监测采集控制短信报警终端&#xff0c;为充电站的安全运行和高效管理提供了强大的技术支持。 技术特点和功能 钡铼S275采用了基于UCOSI…

Android11 窗口动画

窗口进入动画 应用端窗口绘制完成之后&#xff0c;调用finshDraw告知WMS&#xff0c;WMS这边最后就会调用WindowSurfacePlacer的performSurfacePlacement方法&#xff0c;最终调用到 WindowStateAnimator的commitFinishDrawingLocked方法 //frameworks/base/services/core/jav…

JS进阶-深入对象

学习目标&#xff1a; 掌握深入对象 学习内容&#xff1a; 创建对象三种方式构造函数实例成员&静态成员 创建对象三种方式&#xff1a; 利用对象字面量创建对象 const o {name: 佩奇}利用new Object创建对象 const obj new Object({ uname: 雪碧宝宝 })console.log(obj…

OJhelper一款帮助你获取各大oj信息的软件

项目地址 应用功能 目前应用支持&#xff1a;查询、自定义、收藏各大oj比赛信息&#xff0c;跳转比赛界面。查询各大oj的Rating分以及题量&#xff0c;查看题量饼状图。 应用环境 windows和安卓端 应用预览&#xff1a; 维护概况 后期会提供持续更新&#xff0c;具体可以…

7.9数据结构

思维导图 作业 doubleloop.h #ifndef __DOUBLELOOP_H__ #define __DOUBLELOOP_H__#include <stdio.h> #include <stdlib.h>typedef int datatype; typedef struct node {union{int len;datatype data;};struct node *pri;//前驱指针struct node *next;//后继指针…

全终端自动化测试框架wyTest

突然有一些觉悟&#xff0c;程序猿不能只会吭哧吭哧的低头做事&#xff0c;应该学会怎么去展示自己&#xff0c;怎么去宣传自己&#xff0c;怎么把自己想做的事表述清楚。 于是&#xff0c;这两天一直在整理自己的作品&#xff0c;也为接下来的找工作多做点准备。接下来…

Linux | 安装lb-toolkits 1.2.4库

Linux | 安装 lb-toolkits 最近又需要下载葵花的数据&#xff0c;之前分享过一次代码。今天发现之前的环境不小心被我删了&#xff0c;而运行相关的代码需要安装lb-toolkits这个库&#xff0c;今天正好记录了一下安装lb-toolkits的过程。 这里安装的版本是1.2.4&#xff0c;别…

windows USB 设备驱动开发-发送MDL和错误恢复

USB 驱动程序可以在堆栈中使用链接式 MDL 功能发送数据&#xff0c;并且USB驱动的客户端可以将传输缓冲区作为 MDL 结构链发送。 大多数 USB 主机控制器要求传输缓冲区几乎是连续的。 几乎连续意味着缓冲区可以开始和结束页中的任意位置&#xff0c;但缓冲区的其余部分必须在页…

53-4 内网代理6 - frp搭建三层代理

前提:53-3 内网代理5 - frp搭建二级代理-CSDN博客 三级网络代理 在办公区入侵后,发现需要进一步渗透核心区网络(192.168.60.0/24),并登录域控制器的远程桌面。使用FRP在EDMZ区、办公区与核心区之间建立三级网络的SOCKS5代理,以便访问核心区的域控制器。 VPS上的FRP服…

海豚调度器(DolphinScheduler)修改时区为东八区

海豚调度器设置了定时&#xff0c;执行的时间和设置时间不同&#xff0c;后来排查发现是时区问题。可以用下面方法和步骤来修改&#xff1a; 修改DolphinScheduler服务器时区 登录服务器&#xff1a;首先&#xff0c;通过SSH或其他方式登录到运行DolphinScheduler服务的服务器…

压缩感知3——重构算法正交匹配追踪算法

算法流程 问题的实质是&#xff1a;AX Y 求解&#xff08;A是M维&#xff0c;Y是N维且N>>M并且稀疏度K<M&#xff09;明显X有无穷多解&#xff0c;重构过程是M次采样得到的采样值升维的过程。OMP算法的具体步骤&#xff1a;(1)用X表示信号&#xff0c;初始化残差e0 …

计算给定数字的阶乘

1 问题 计算给定数字的阶乘. 2 方法 使用while循环。使用for循环。使用函数。 通过实验、实践等证明提出的方法是有效的&#xff0c;是能够解决开头提出的问题。 代码清单 1 使用while循环numberint(input(请输入一个数字:))factorial1i1while i<number: factorialfactor…

【论文速读】| JADE:用于大语言模型的基于语言学的安全评估平台

本次分享论文&#xff1a;JADE : A Linguistics-based Safety Evaluation Platform for Large Language Models 基本信息 原文作者&#xff1a;Mi Zhang, Xudong Pan, Min Yang 作者单位&#xff1a;Whitzard-AI, System Software and Security Lab Fudan University 关键…

AWS Glue 与 Amazon Redshift 的安全通信配置

1. 引言 在 AWS 环境中,确保服务间的安全通信至关重要。本文将探讨 AWS Glue 与 Amazon Redshift 之间的安全通信配置,特别是为什么需要特定的安全组设置,以及如何正确实施这些配置。 2. 背景 AWS Glue:全托管的 ETL(提取、转换、加载)服务Amazon Redshift:快速、完全…

嵌入式底层开发 入门学习路线

入门嵌入式底层开发的学习路线可以分为几个关键阶段&#xff0c;下面是一个较为系统的学习路径&#xff0c;它涵盖了从基础知识到实际项目应用的全过程。 1. 基础知识 计算机科学基础&#xff1a;理解数据结构、算法、操作系统等基本概念。电子和电路理论&#xff1a;学习数字…

『大模型笔记』GraphRAG:用于复杂数据发现的新工具现已在GitHub上发布

GraphRAG:用于复杂数据发现的新工具现已在GitHub上发布 文章目录 一. GraphRAG:用于复杂数据发现的新工具现已在GitHub上发布1. 评估和结果2. 研究见解和未来方向二. 参考文献一. GraphRAG:用于复杂数据发现的新工具现已在GitHub上发布 下载 GraphRAG今年早些时候,我们介绍…

倒计时 2 周!CommunityOverCode Asia 2024 IoT Community 专题部分

CommunityOverCode 是 Apache 软件基金会&#xff08;ASF&#xff09;的官方全球系列大会&#xff0c;其前身为 ApacheCon。自 1998 年以来&#xff0c;在 ASF 成立之前&#xff0c;ApacheCon 已经吸引了各个层次的参与者&#xff0c;在 300 多个 Apache 项目及其不同的社区中探…

【Unix】SunOS/Oracle Solaris系统介绍

一.SunOS系统介绍 SunOS 是由 Sun Microsystems 开发的 Unix 操作系统。它最初是为 Sun 的 SPARC 架构计算机设计的&#xff0c;后来也支持了 Intel x86 架构。SunOS 是基于 UNIX System V 4.1 版本&#xff0c;并且随着时间的发展&#xff0c;SunOS 经历了多个版本迭代&#…