原文:http://www.cnblogs.com/AndyJee/p/4483043.html

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个孩子站成一排,给每个人设定一个权重(已知)。按照如下的规则分配糖果: (1)每个孩子至少分得一颗糖果 (2)权重较高的孩子,会比他的邻居获得更多的糖果。

问:总共最少需要多少颗糖果?请分析算法思路,以及算法的时间,空间复杂度是多少。

思路:

假设每个孩子分到的糖果数组为A[N],初始化为{1},因为每个人至少分到一颗糖。

方法一:

1、与前面的邻居比较,前向遍历权重数组ratings,如果ratings[i]>ratings[i-1],则A[i]=A[i-1]+1;

2、与后面的邻居比较,后向遍历权重数组ratings,如果ratings[i]>ratings[i+1]且A[i]<A[i+1]+1,则更新A,A[i]=A[i+1]+1;

3、对A求和即为最少需要的糖果。

时间复杂度:O(n)

空间复杂度:O(n)

leetcode上的原题,先每人发一颗糖。第一遍从前往后扫描,满足相邻两个小孩后面的权重大于前面的权重的情况,后面的小孩在前面的小孩的糖果数的基础上加一个。第二遍从后往前扫描,满足条件与第一遍扫描一样。这样两遍扫描下来就可以保证权重高的孩子比相邻权重低的孩子的糖果多。时间复杂度是O(n),空间复杂度是O(n)。

方法二:

设数组A1,保存前向遍历的结果,设数组A2,保存后向遍历的结果;

1、与前面的邻居比较,前向遍历权重数组ratings,如果ratings[i]>ratings[i-1],则A1[i]=A1[i-1]+1;

2、与后面的邻居比较,后向遍历权重数组ratings,如果ratings[i]>ratings[i+1],则A2[i]=A2[i+1]+1;

3、每个孩子分到的糖果比前后邻居多,为A1、A2的较大者,即A[i]=max(A1[i],A2[i]);

4、对A求和即为最少需要的糖果。

时间复杂度:O(n)

空间复杂度:O(n)

代码:

class Solution {
public:
int candy(vector<int>& ratings) {
int n=ratings.size();
int sum; vector<int> nums(n,1);
for(int i=1;i<n;i++){
if(ratings[i]>ratings[i-1])
nums[i]=nums[i-1]+1;
} sum=nums[n-1];
for(int i=n-2;i>=0;i--){
if(ratings[i]>ratings[i+1] && nums[i]<nums[i+1]+1)
nums[i]=nums[i+1]+1;
sum+=nums[i];
} return sum;
}
};
class Solution {
public:
int candy(vector<int>& ratings) {
int n=ratings.size();
int sum=0; vector<int> nums(n,1);
vector<int> for_nums(n,1);
vector<int> back_nums(n,1); for(int i=1;i<n;i++){
if(ratings[i]>ratings[i-1])
for_nums[i]=for_nums[i-1]+1;
} for(int i=n-2;i>=0;i--){
if(ratings[i]>ratings[i+1])
back_nums[i]=back_nums[i+1]+1;
} for(int i=0;i<n;i++){
nums[i]=max(for_nums[i],back_nums[i]);
sum+=nums[i];
} return sum;
}
};

(LeetCode 135) Candy N个孩子站成一排,给每个人设定一个权重的更多相关文章

  1. LeetCode 135 Candy(贪心算法)

    135. Candy There are N children standing in a line. Each child is assigned a rating value. You are g ...

  2. (动态规划)有 n 个学生站成一排,每个学生有一个能力值,从这 n 个学生中按照顺序选取kk 名学生,要求相邻两个学生的位置编号的差不超过 d,使得这 kk 个学生的能力值的乘积最大,返回最大的乘积

    第2关:最强战队 挑战任务 绿盟和各大名企合作,举办编程能力大赛,需要选拔一支参赛队伍.队伍成员全部来自“绿盟杯”中表现优秀的同学,每个同学都根据在比赛中的表现被赋予了一个能力值.现在被召集的N个同学 ...

  3. leetcode 135. Candy ----- java

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

  4. Leetcode#135 Candy

    原题地址 遍历所有小孩的分数 1. 若小孩的分数递增,分给小孩的糖果依次+12. 若小孩的分数递减,分给小孩的糖果依次-13. 若小孩的分数相等,分给小孩的糖果设为1 当递减序列结束时,如果少分了糖果 ...

  5. Java for LeetCode 135 Candy

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

  6. [leetcode] 135. Candy (hard)

    原题 前后两遍遍历 class Solution { public: int candy(vector<int> &ratings) { vector<int> res ...

  7. Java实现 LeetCode 135 分发糖果

    135. 分发糖果 老师想给孩子们分发糖果,有 N 个孩子站成了一条直线,老师会根据每个孩子的表现,预先给他们评分. 你需要按照以下要求,帮助老师给这些孩子分发糖果: 每个孩子至少分配到 1 个糖果. ...

  8. Leetcode 135.分糖果

    分发糖果 老师想给孩子们分发糖果,有 N 个孩子站成了一条直线,老师会根据每个孩子的表现,预先给他们评分. 你需要按照以下要求,帮助老师给这些孩子分发糖果: 每个孩子至少分配到 1 个糖果. 相邻的孩 ...

  9. [LeetCode] 135. 分发糖果

    题目链接 : https://leetcode-cn.com/problems/candy/ 题目描述: 老师想给孩子们分发糖果,有 N 个孩子站成了一条直线,老师会根据每个孩子的表现,预先给他们评分 ...

随机推荐

  1. 非阻塞式socket的select()用法

    Select在Socket编程中还是比较重要的,可是对于初学Socket的人来说都不太爱用Select写程序,他们只 是习惯写诸如 connect.accept.recv或recvfrom这样的阻塞程 ...

  2. 第一百九十六天 how can I 坚持

    老妈邮的咸菜到了,美味啊,买不到,哈哈. 以后要勤给鱼换水啊,10天不换,水都臭了,拒绝懒惰. 明天要回济南了,刘松结婚,估计又没法发博客了. 两条鱼,一条罗娜,一条我,哈哈. 睡觉.

  3. 转】MyEclipse使用总结——使用MyEclipse打包带源码的jar包

    原博文出自于: http://www.cnblogs.com/xdp-gacl/p/4136303.html 感谢! 平时开发中,我们喜欢将一些类打包成jar包,然后在别的项目中继续使用,不过由于看不 ...

  4. windows下揪出java程序占用cpu很高的线程 并找到问题代码 死循环线程代码

    我的一个java程序偶尔会出现cpu占用很高的情况 一直不知道什么原因 今天终于抽时间解决了 系统是win2003 jvisualvm 和 jconsole貌似都只能看到总共占用的cpu 看不到每个线 ...

  5. android学习笔记(入门篇)

    +号只是当你第一次定义一个资源ID的时候需要, 告诉SDK此资源ID需要被创建出来 对于所有的View默认的权重是0,如果你只设置了一个View的权重大于0,那么这个View将占据除去别的View本身 ...

  6. Options for Debugging Your Program or GCC

    [Options for Debugging Your Program or GCC] -g Produce debugging information in the operating system ...

  7. Spring中的BeanUtils与apache commons中的BeanUtils用法[1]

    1. 前言 在开发过程中,经常遇到把要给一个bean的属性赋给另外一个bean.最笨的方法是每个属性都单独写一个,聪明的方法是应用反射写一个工具方法.考虑到这个需求基本每个程序员都会遇到,那么一定已经 ...

  8. Codeforces 711 C. Coloring Trees (dp)

    题目链接:http://codeforces.com/problemset/problem/711/C 给你n棵树,m种颜色,k是指定最后的完美值.接下来一行n个数 表示1~n树原本的颜色,0的话就是 ...

  9. HDU1963Investment(DP)

    简单DP,题解见代码

  10. Java和MongoDB之Hello World

    1.新建Project 新建Java Project,并把mongo-java-driver驱动加入到项目bulid path中,如果你使用的是maven增加依赖. <dependency> ...