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

You are giving candies to these children subjected to the following requirements:

  • Each child must have at least one candy.
  • Children with a higher rating get more candies than their neighbors.

What is the minimum candies you must give?

题目的意思是 有N个孩子排成一排,并给每个孩子分配一个rating值。按照如下规则给孩子们分配糖果:

(1) 每个孩子必须分至少一个糖果。

(2)相邻的孩子间,具有高rating值的孩子要多得一个糖果。

按照题目的意思,我们给定一个序列:

(1)递增序列

  1 5 7 9

  很容易得到分配的糖果数依次为:1,2,3,4

(2)递减序列

  8 6 4 2

  也很容易得到分配的糖果数依次为:4,3,2,1

(3)单波形序列

  1 3 5 7 6 4 

  有两个子序列: 1,3,5,7 以及7,6,4

  对应分配糖果序列:1,2,3,4 以及3,2,1

  在此过程中7,在两个序列中都出现了,但是在左边需要分配4颗糖,在右边则要分配3颗糖,那么在最终的序列中需要分配多的一端。因此最后的分配序列为:

  1,2,3,4,2,1   sum= 1+2+3+4+2+1 = 13

  7 5 4 3 9 10

  有两个子序列: 7,5,4,3 以及3,9,10

  分配按照子序列发糖: 4,3,2,1 以及1,2,3

  默认最小的值分配最少的糖,1颗。因此最后的分配序列为:

  4,3,2,1,2,3  sum = 4+3+2+1+2+3 = 15

(4)多波形

  1 2 3 9 8 7 5 2 4 6 5 3 4

  看似无序,但是可以分成多个递增和递减序列

  递增序列:     1 2 3 9 _ _ _ 2 4 6 _ 3 4

  递减序列:     _ _ _ 9 8 7 5 2 _ 6 5 3 _

  增序列分配:   1 2 3 4 _ _ _ 1 2 3 _ 1 2

  减序列分配:   _ _ _ 5 4 3 2 1 _ 3 2 1 _

  最终的分配结果:  1 2 3 5 4 3 2 1 2 3 2 1 2 

经过上述分析,可以看出糖果的分配可以分成两种序列进行分配,一种是非增序列,另一中则是非减序列

分别定义两个序列 up 以及down,分别记录非减序列和非增序列

(1)从头至尾遍历一次,找出递增序列up

  array up initial with all element equals to 1

  for i from ratings.begin to ratings.end

  do

    if   ratings[i] > ratings [i-1] then

      up[i] <- up[i-1] +1

    end if

(2)从尾向头遍历一次,找出递减序列down

  array down initial with all element equals to 1

  for i from ratings.rbegin to ratings.rend

  do

    if   ratings[i] > ratings [i+1] then

      up[i] <- up[i+1] +1

    end if

(3) 比较up 和down 相应位置,选择较大的值作为最终结果

  sum <- 0

  for i from ratings.begin to ratings.end

  do

    sum <-  sum + max{up[i], down[i]}

  end for

  return sum

 class Solution {
public:
int candy(vector<int> &ratings) {
int len = ratings.size();
if(len<=) return len;
int i,tot=;
vector<int> up(len,);
vector<int> down(len,);
for(i=;i<len;i++)
if(ratings[i]>ratings[i-]) up[i] = up[i-]+;
for(i=len-;i>=;i--)
if(ratings[i]>ratings[i+]) down[i]= down[i+]+;
for(i=;i<len;i++){
tot += max(up[i],down[i]);
}
return tot;
}
};

转载请注明出处: http://www.cnblogs.com/double-win/ 谢谢

[LeetCode 题解]:Candy的更多相关文章

  1. leetcode题解 candy

    要求的条件是: 1.每个人最少一个糖果. 2.相邻的小朋友,要保证,评分高的比评分低的糖果多. 如果从一侧扫描的话,容易确定的就是递增序列,只要上升1个就够了. 容易出现问题的就是:遇到下降期,或者相 ...

  2. 【LeetCode题解】二叉树的遍历

    我准备开始一个新系列[LeetCode题解],用来记录刷LeetCode题,顺便复习一下数据结构与算法. 1. 二叉树 二叉树(binary tree)是一种极为普遍的数据结构,树的每一个节点最多只有 ...

  3. leetcode题解-122买卖股票的最佳时期

    题目 leetcode题解-122.买卖股票的最佳时机:https://www.yanbinghu.com/2019/03/14/30893.html 题目详情 给定一个数组,它的第 i 个元素是一支 ...

  4. 【LeetCode题解】3_无重复字符的最长子串(Longest-Substring-Without-Repeating-Characters)

    目录 描述 解法一:暴力枚举法(Time Limit Exceeded) 思路 Java 实现 Python 实现 复杂度分析 解法二:滑动窗口(双指针) 思路 Java 实现 Python 实现 复 ...

  5. 【LeetCode题解】225_用队列实现栈(Implement-Stack-using-Queues)

    目录 描述 解法一:双队列,入快出慢 思路 入栈(push) 出栈(pop) 查看栈顶元素(peek) 是否为空(empty) Java 实现 Python 实现 解法二:双队列,入慢出快 思路 入栈 ...

  6. 【LeetCode题解】232_用栈实现队列(Implement-Queue-using-Stacks)

    目录 描述 解法一:在一个栈中维持所有元素的出队顺序 思路 入队(push) 出队(pop) 查看队首(peek) 是否为空(empty) Java 实现 Python 实现 解法二:一个栈入,一个栈 ...

  7. 【LeetCode题解】844_比较含退格的字符串(Backspace-String-Compare)

    目录 描述 解法一:字符串比较 思路 Java 实现 Python 实现 复杂度分析 解法二:双指针(推荐) 思路 Java 实现 Python 实现 复杂度分析 更多 LeetCode 题解笔记可以 ...

  8. 【LeetCode题解】25_k个一组翻转链表(Reverse-Nodes-in-k-Group)

    目录 描述 解法一:迭代 思路 Java 实现 Python 实现 复杂度分析 解法二:递归(不满足空间复杂度) 思路 Java 实现 Python 实现 复杂度分析 更多 LeetCode 题解笔记 ...

  9. 【LeetCode题解】24_两两交换链表中的节点(Swap-Nodes-in-Pairs)

    目录 描述 解法一:迭代 思路 Java 实现 Python 实现 复杂度分析 解法二:递归(不满足空间复杂度要求) 思路 Java 实现 Python 实现 复杂度分析 更多 LeetCode 题解 ...

  10. 【LeetCode题解】347_前K个高频元素(Top-K-Frequent-Elements)

    目录 描述 解法一:排序算法(不满足时间复杂度要求) Java 实现 Python 实现 复杂度分析 解法二:最小堆 思路 Java 实现 Python 实现 复杂度分析 解法三:桶排序(bucket ...

随机推荐

  1. 多线程环境下的UI异步操作

    转自原文 多线程环境下的UI异步操作 解决VS中,线程间不可互操作的问题,一揽子解决方案: 一.首先,定义一个类:SetControlProperty using System.Reflection; ...

  2. 手游为什么要热更新,C#为什么不能热更新,LUA为什么可以

    热更新是什么?简单的说就是打补丁,只补需要部分,不用重个游戏包重打上传 热更新问题的本质是代码更新而不是资源更新,为什么呢? 大型手游都是将补丁资源放在专门的WEB服务器上,游戏启动时动态下载并放入到 ...

  3. hibernate中 criteria.setProjection(Projections.rowCount()).uniqueResult()为null的Bug

    在hibernate中,在查询总数时,会使用如下方法; public Integer getCount(final DetachedCriteria detachedCriteria) {       ...

  4. 如何用keytool导入证书

    先用cmd定位到 jre\lib目录下的security文件夹   例如 C:\Program Files\Java\jre1.8.0_191\lib\security 运行cmd,导入证书 keyt ...

  5. (转) Linux下配置nfs并远程挂载

    nfs是网络文件系统,允许一个节点通过网络访问远程计算机的文件系统,远程文件系统可以被直接挂载到本地,文件操作和本地没有区别,如果是局域网的nfs那么io的性能也可以保证,下面就以CentOS 7.x ...

  6. 201671010127 2016-2017-11 Java图形用户界面设计技术

    一.事件处理器 1.什么是事件处理 一个事件要求特定的动作被执行,它被作为消息由外界或系统自身发送给GUI系统.这些事件包括来自计算机设备如鼠标键盘和网络端口的I/O中断,以及GUI系统的逻辑事件触发 ...

  7. Creating Cubemaps in Unity3D

    [Creating Cubemaps in Unity3D] 1.在Editor目录下生成GenerateStaticCubemap.cs. 2.编写代码,生成一个继承于ScriptableWizar ...

  8. GameObject.Find 使用技巧

    GameObject.Find是全局搜索 如果你已经知道这个元件在哪个元件里面的话,且担心场景中有重名元件,可以这样写 GameObject.Find ("Canvas/Panel/Imag ...

  9. 校准liunx时间简单好用的命令

    查看时间服务器的时间# rdate time-b.nist.gov 设置时间和时间服务器同步# rdate -s time-b.nist.gov 查看硬件时间 # hwclock 将系统时间写入硬件时 ...

  10. ubuntu Qt5 opencv3.4 项目配置

    #------------------------------------------------- # # Project created by QtCreator 2019-03-25T14:14 ...