【LeetCode】贪心算法--分发糖果(135)
今日题目
老师想给孩子们分发糖果,有N个孩子站成了一条直线,老师会根据每个孩子的表现,预先给他们评分。
你需要按照以下要求,帮助老师给这些孩子分发糖果:
每个孩子至少分配到 1 个糖果。相邻的孩子中,评分高的孩子必须获得更多的糖果。那么这样下来,老师至少需要准备多少颗糖果呢?
示例 1:
输入: [1,0,2]
输出: 5
解释: 你可以分别给这三个孩子分发 2、1、2 颗糖果。
示例 2:
输入: [1,2,2]
输出: 4
解释: 你可以分别给这三个孩子分发 1、2、1 颗糖果。第三个孩子只得到 1 颗糖果,这已满足上述两个条件。
题目分析
对于这个问题,主要的条件是要相邻孩子,得分高的拿的糖果要多(不包括相等得分),还有就是每个人最少都要有一个。
解决这个问题我们还是采用贪心算法,首先初始化每个人分配的糖果数量都是1,然后这个算法需要遍历两遍,第一遍从左往右遍历,如果当前孩子的分数大于前一个孩子的分数,则当前孩子得到的糖果在前一个孩子的基础上加1;然后,第二遍从右往左遍历,如果当前孩子的分数大于他右边孩子的分数,并且他的糖果不比他右边孩子多,则糖果数在他基础上加1;最后,将所有孩子的糖果数相加即可。
第二次遍历是为了处理数组中降序和有出现相邻孩子分数相同的情况。
代码实现
class Solution:
def candy(self, ratings):""":type ratings: List[int]:rtype: int"""num = [1]*len(ratings)for i in range(0,len(ratings)-1):if ratings[i+1] > ratings[i]:num[i+1] = num[i] + 1 for i in range(len(ratings)-1,0,-1):if ratings[i] < ratings[i-1]:num[i-1] = max(num[i]+1,num[i-1])return sum(num)
写在最后
寒假已经跟一个小伙伴商量好一起刷题,感兴趣的小伙伴也可以加入我们,希望大家每天可以交流刷题的心得,为了保证质量我会控制人数,大约在12人左右。
推荐阅读:
Python骚操作 | 用Python来P图
【LeetCode】贪心算法--分发糖果(135)相关推荐
- leetcode贪心算法题集锦(持续更新中)
leetcode贪心算法题集锦 leetcode贪心算法题集锦(持续更新中).python 和C++编写. 文章目录 leetcode贪心算法题集锦 一.贪心算法 1.盛最多水的容器 2.买股票的最佳 ...
- 八十二、Python | Leetcode贪心算法系列
@Author:Runsen @Date:2020/7/5 人生最重要的不是所站的位置,而是内心所朝的方向.只要我在每篇博文中写得自己体会,修炼身心:在每天的不断重复学习中,耐住寂寞,练就真功,不畏艰 ...
- python leetcode_八十二、Python | Leetcode贪心算法系列
@Author:Runsen @Date:2020/7/5 人生最重要的不是所站的位置,而是内心所朝的方向.只要我在每篇博文中写得自己体会,修炼身心:在每天的不断重复学习中,耐住寂寞,练就真功,不畏艰 ...
- LeetCode 135. 分发糖果(贪心算法)
题目描述 老师想给孩子们分发糖果,有 N 个孩子站成了一条直线,老师会根据每个孩子的表现,预先给他们评分. 你需要按照以下要求,帮助老师给这些孩子分发糖果: 每个孩子至少分配到 1 个糖果. 相邻的孩 ...
- 通俗易懂:贪心算法(一):分配问题 (力扣455分发饼干 和135分发糖果)
看完本文,可以顺便解决leetcode以下两个题目: 455.分发饼干(简单) 135.分发糖果(困难) 一.通俗易懂的 贪心算法 |思想 贪心算法就是采用贪心的策略,保证每一次的操作都是局部最优的, ...
- LeetCode算法题0:分发糖果【贪心算法】
文章目录 前言 一.题目 二.思路详解 三.搞点实际点儿的(C++实现) 1.略显粗糙的代码实现 2.稍显精致的代码实现 3.最终的代码实现 4.提交结果 总结 前言 本文记录自己在LeetCode上 ...
- 135. 分发糖果(贪心算法)
老师想给孩子们分发糖果,有 N 个孩子站成了一条直线,老师会根据每个孩子的表现,预先给他们评分. 你需要按照以下要求,帮助老师给这些孩子分发糖果: 每个孩子至少分配到 1 个糖果. 评分更高的孩子必须 ...
- 135. 分发糖果002(贪心算法+思路+详解)
一:题目 老师想给孩子们分发糖果,有 N 个孩子站成了一条直线,老师会根据每个孩子的表现,预先给他们评分. 你需要按照以下要求,帮助老师给这些孩子分发糖果: 每个孩子至少分配到 1 个糖果. 评分更高 ...
- LeetCode 135. 分发糖果(DP)
1. 题目 老师想给孩子们分发糖果,有 N 个孩子站成了一条直线,老师会根据每个孩子的表现,预先给他们评分. 你需要按照以下要求,帮助老师给这些孩子分发糖果: 每个孩子至少分配到 1 个糖果. 相邻的 ...
最新文章
- 监控Tomcat解决方案(监控应用服务器系列文章分享)
- Django从理论到实战(part24)--在模板中访问静态文件
- 【译】使用Blazor构建桌面应用
- object htmldivelement什么意思_深入探究 Function amp; Object 鸡蛋问题
- 目录服务软件 AD和LDAP 的理解
- linux登录指令 pgsql_命令行方式登录PostgreSQL
- Android 自定义View -- 简约的折线图
- Bleu:此'蓝'非彼蓝
- 阶段1 语言基础+高级_1-3-Java语言高级_06-File类与IO流_08 转换流_2_编码引出的问题_FileReader读取GBK格式文件...
- 所有快捷方式失效的解决方法
- dex2jar 报错 com.googlecode.d2j.DexException: not support version
- excel表格如何画斜线并写字
- java基础教程推荐_推荐Java入门视频教程
- mr.baidu.com百度官方缩短网址接口网站调用生成制作方法解析
- Vue3实现中英文切换
- 7 进度指示器(LinearProgressIndicator、CircularProgressIndicator)
- 高清视频会议终端市场现状及未来发展趋势分析
- 自动控制原理(1)- 介绍与数学模型
- HTML如何给网页添加ico图标?
- 计算机怎样结束应用进程,结束进程,详细教您电脑怎么结束进程
热门文章
- BZOJ1044: [HAOI2008]木棍分割(dp 单调队列)
- 进程和线程的区别, 面相对象补充, 进程, 数据共享, 锁, 进程池, 爬虫模块(requests, bs4(beautifulsoup))...
- 宝马与intel合作 2021年推全自动无人驾驶车
- 小学信息技术用计算机编辑文档教案,小学信息技术《初识文字处理软件》教案.doc...
- 多线程 转账_Java多线程编程基础三(原子性,可见性和有序性)
- php连贯操作,Thinkphp 3.2.3 sql的一些连贯操作方法
- css如何设置文本垂直居中显示,css中怎么设置文本居中?css文本垂直居中的设置方法...
- linux oracle dblink,Oracle 创建 DBLink 的方法
- vv7无法启动显示发动机故障_发动机电控系统常见故障(发动机不能启动)的解决方法...
- Python中的Monkey Patch(猴子补丁)