题目要求的比它的邻居比自己奖励,因此,我们有最少一个多的。所有我们可以找到所有的坑,凹坑例如,存在以下三种情况。

找到全部的凹点后,我们就能够从凹点处開始向左右两个方向依次查找递增序列。当中每一个高的都要比相邻的矮的多一个。比方1,2,5,4.我们找到凹点为1 和4,那么从1開始向左没有其它点,我们向右,依次得到2 比1高,2的糖果应该是1的基础上加1。为2, 5比2高,5的糖果是在2的基础上加1,为3。

令一个凹点4, 向左,5比4高,5的糖果应该是在4的基础上加 1,为2,这时我们发现冲突了,从凹点1 開始,我们得到的5的糖果是3。可是从凹点 4 開始,我们得到的糖果数却为2 ,此时我们选择哪个呢?当然,假设要少的,当然是2,可是它却违反了题目中的限定条件。5假设为2
,就不比2的糖果数多了,所以这时我们就应该选择最大的,这说明了什么呢?说明从左面開始向右到 5 得到的递增序列的长度大于从4開始向左到5得到的递增序列。

也就是说,得到的糖果数的多少,取决于所构成的连续递增序列的长度。

class Solution:
def candy(self, A):
if len(A) == 0: return 0
candies = [1] * len(A)
#insert two guard at both bounder
#为了便于处理凹点,我们在左右边界各插入一个点作为哨兵,这样在比較的时候
#就不用额外处理边界点了。 A.insert(0, A[0])
A.append(A[-1])
#pits 用来存储全部的凹点下标
pits = []
for i in range(1, len(A) - 1):
if A[i] <= A[i - 1] and A[i] < A[i + 1] or \
A[i] <= A[i + 1] and A[i] < A[i - 1]:
pits.append(i)
#从左到右一次处理各个凹点
for i in pits:
# go left
j = i
while A[j - 1] > A[j]:
#由于A数组增加了哨兵的缘故,所以A和candies的下标不是严格对齐的,差了一个
if candies[j - 2] < candies[j - 1] + 1:
candies[j - 2] = candies[j - 1] + 1
j -= 1
else: break
# go right
j = i
while A[j + 1] > A[j]:
if candies[j] < candies[j - 1] + 1:
candies[j] = candies[j - 1] + 1
j += 1
else: break
return sum(candies)

这里我们须要一个额外的pits数组来存储全部的凹点,事实上通过刚才我们的分析,第二种实现方式已经出现了,就是从左開始,找递增序列,然后添加糖果。对于每一个数,它和左边构成的递增序列与从右面构成的递增序列可能不一样,如上例中的5,跟左边够成的递增序列为 1,2 5,长度为3,跟右面的构成的递增序列为4,5,长度为2,而5最少的糖果数是取决于最长的递增序列的。所以我们就能够从左到右遍历一遍。然后再从右向左遍历一遍。取两次遍历的最大值。

class Solution:
def candy(self, A):
if len(A) == 0: return 0
candies = [1] * len(A)
#从左向右,按着递增来分配糖果
for i in range(1, len(A)):
if A[i] > A[i - 1]:
candies[i] = candies[i - 1] + 1 #从右向左,按着递增来分配糖果。并取最大值
for i in xrange(len(A) - 2, -1, -1):
if A[i] > A[i + 1] and candies[i] < candies[i + 1] + 1:
candies[i] = candies[i + 1] + 1 return sum(candies)

版权声明:本文博客原创文章,博客,未经同意,不得转载。

【leetcode】Candy(python)的更多相关文章

  1. 【leetcode】Candy(hard) 自己做出来了 但别人的更好

    There are N children standing in a line. Each child is assigned a rating value. You are giving candi ...

  2. 【leetcode】4Sum(middle)

    Given an array S of n integers, are there elements a, b, c, and d in S such that a + b + c + d = tar ...

  3. NoSQL之【MongoDB】学习(三):配置文件说明

    摘要: 继上一篇NoSQL之[MongoDB]学习(一):安装说明 之后,知道了如何安装和启动MongoDB,现在对启动时指定的配置文件(mongodb.conf)进行说明,详情请见官方. 启动Mon ...

  4. 【操作系统】进程间通信(C#)

    原文:[操作系统]进程间通信(C#) 08年9月入学,12年7月毕业,结束了我在软件学院愉快丰富的大学生活.此系列是对四年专业课程学习的回顾,索引参见:http://blog.csdn.net/xia ...

  5. 【Luogu3444】ORK-Ploughing(贪心)

    [Luogu3444]ORK-Ploughing(贪心) 题面 Luogu 题解 我们知道,如果我们选定了以横向为主,或者纵向为主, 那么就有尽可能减少另一个方向上耕地的次数 所以分开贪心,但是本质相 ...

  6. 【BZOJ1997】Planar(2-sat)

    [BZOJ1997]Planar(2-sat) 题面 BZOJ 题解 很久没做过\(2-sat\)了 今天一见,很果断的就来切 这题不难呀 但是有个玄学问题: 平面图的性质:边数\(m\)的最大值为\ ...

  7. 【Luogu1337】平衡点(模拟退火)

    [Luogu1337]平衡点(模拟退火) 题面 洛谷 题解 和BZOJ3680吊打XXX是一样的.. 但是数据很强呀.. 疯狂调参 各种WA... 很无奈呀.... #include<iostr ...

  8. 【BZOJ1996】合唱队(动态规划)

    [BZOJ1996]合唱队(动态规划) 题面 BZOJ 题解 很容易的一道题 因为每个人不是放在了左边就是放在了右边 所以每次放好的人必定是原序列的一个子串 所以,很容易想到区间\(dp\) 设\(f ...

  9. 【BZOJ1899】午餐(动态规划)

    [BZOJ1899]午餐(动态规划) 题面 BZOJ 题解 我太弱了 这种\(dp\)完全做不动.. 首先,感性理解一些 如果所有人都要早点走, 那么,吃饭时间长的就先吃 吃饭时间短的就晚点吃 所以, ...

随机推荐

  1. LLBL Gen Pro 5.0

    LLBL Gen Pro 5.0 企业应用开发入门 Solutions Design 公司于2016年5月发布了LLBL Gen Pro 5.0,这个新版本的发布出乎于我的意料.我的猜想是从4.2升级 ...

  2. zabbix 监控jvm

    tomcat 机器配置: [root@wx03 lib]# pwd /usr/local/apache-tomcat-7.0.55/lib [root@wx03 lib]# ls -ltr *jmx* ...

  3. DFA最小化 -- Hopcroft算法 Python实现

    wiki 伪代码看上去一直以为怪.发现葡萄牙语和俄罗斯语那里的 if 推断都还缺少一个条件. 国内的资料比較少.这几份学习资料不错.比我稀里糊涂的思路要好,分享下: http://www.liafa. ...

  4. C++ Primer 学习笔记_60_重载操作符与转换 --赋值、下标、成员訪问操作符

    重载操作符与转换 --赋值.下标.成员訪问操作符 一.赋值操作符 类赋值操作符接受类类型形參,通常该形參是对类类型的const引用,但也能够是类类型或对类类型的非const引用.假设未定义这个操作符, ...

  5. linux公社的大了免费在线android资料

    2011年linux数据库的android在线分享 linux公社:开源公社             本文撰写:杨凯专属频道 2011年9月12日 21:39 <目录> Android 3 ...

  6. WAS ND集群中的HTTP内存会话复制对Java应用程序序列化编程的要求

    应用程序需要遵守的约定 在会话中没有自定义对象时,WAS 集群的 HTTP 会话内存复制特性成功地实现了高可用性,使用户在宕机过程中的会话信息没有丢失,操作没有受到任何影响. 在会话中包含自定义对象时 ...

  7. 8086 CPU 寻址方式

    8086 CPU 寻址方式灵活.有以下几种 idata 表示常量 1.   [ idata ] 用一个常量来表示地址,可用于直接定位内存单元,但是在 MASM中要显实在的说明 ds 段寄存器, 比如 ...

  8. Cocos2dx-Android 之Makefile通用高级写法

    不废话,直接贴.节约时间.须要改进的地方请各位指出.共同学习. LOCAL_PATH := $(call my-dir) include $(CLEAR_VARS) LOCAL_MODULE := c ...

  9. haproxy 看到的是https,后台是http的原因

    https://www.zjtest6.com/admin/api/menu haproxy 日志: Jun 24 13:23:02 localhost haproxy[23205]: 192.168 ...

  10. 推动Common Lisp的实际应用

    推动Common Lisp的实际应用 推动Common Lisp的实际应用