原文: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. TCP/IP 相关知识点与面试题集

    第一部分:TCP/IP相关知识点 对TCP/IP的整体认 链路层知识点 IP层知识点 运输层知识点 应用层知识点 (这些知识点都可以参考:http://www.cnblogs.com/newwy/p/ ...

  2. 如何创建Asp.net MVC ViewModel

    ASP.NET MVC View Model Patterns Since MVC has been released I have observed much confusion about how ...

  3. 在mac上搭建python环境

    原文出处:http://blog.justbilt.com/2014/07/02/setup_python_on_mac/ 这两天重新搞了下python的环境,发现好多地方还是容易忘记,因此有了这篇文 ...

  4. js获取时间搓

    var oData=new Date().getTime(2016-01-16); console.log(oData);

  5. Application_Error

    //出现未捕捉的异常时,系统调用本方法,一般用于记录日志.错误页的重定向一般在web.config中设置.        protected void Application_Error(object ...

  6. Labview二进制文件的操作

  7. 1001.A+B Format (20)(思路,bug发现及其修改,提交记录)

    https://github.com/031502316a/object-oriented/tree/master/1001 ---恢复内容开始--- 1.解题思路 一开始见到题目时,感觉难的就是输出 ...

  8. UVaLive 7512 November 11th (思维漏洞)

    题意:给定n*m个座椅,然后有b个是坏的,要做人,并且两个人不能相邻,问你最多坐多少人,最少坐多少人. 析:这个题其实并不难,只要当时一时没想清楚,结果就一直WA,就是最少的情况时,其实一个人可以占三 ...

  9. HDU 5778 abs (素数,暴力)

    题意:给定一个数x,求正整数y≥2y\geq 2y≥2,使得满足以下条件: 1.y-x的绝对值最小 2.y的质因数分解式中每个质因数均恰好出现2次. 析:由于y质因数分解式中每个质因数均出现2次,那么 ...

  10. .NET文件上传的大小限制配置

    <system.web>  <!--maxRequestLength单位是Kb-->  <httpRuntime maxRequestLength="20971 ...