Hard-题目34:135. Candy

转载 2016年05月31日 23:44:51

题目原文:
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个小朋友站成一片,每个小朋友有一个评分。
现在要给这N个小朋友发糖,要求每个小朋友至少一个糖,且相邻两个小朋友中,评分高者要比评分低者得到的糖多。
请问至少需要准备多少颗糖?
题目分析:
使用贪心法来做,首先给每个小朋友一个糖,然后从左到右扫描数组,如果i号小朋友的评分高于i-1号,则给i号小朋友的糖是i-1号小朋友+1,再从右到左扫描数组,如果i号小朋友比i+1号小朋友评分高,则给i号小朋友的糖数是i+1号小朋友和i-1号小朋友的糖数最大值+1.
源码:(language:cpp)

class Solution {
public:
  int candy(vector<int> &ratings)
 {
     int size=ratings.size();
     if(size<=1)
         return size;
     vector<int> num(size,1);
     for (int i = 1; i < size; i++)
     {
         if(ratings[i]>ratings[i-1])
             num[i]=num[i-1]+1;
     }
     for (int i= size-1; i>0 ; i--)
     {
         if(ratings[i-1]>ratings[i])
             num[i-1]=max(num[i]+1,num[i-1]);
     }
     int result=0;
     for (int i = 0; i < size; i++)
     {
         result+=num[i];
        // cout<<num[i]<<" ";
     }
     return result;
 }
};

成绩:
40ms,22.09%,40ms,65.85%
Cmershen的碎碎念:
这道题好像今年alibaba的实习生机试里面考了原题,因此leetcode应重视,如果公司出题人懒,就直接从leetcode里面找题了。

[leetcode-135]Candy(java)

问题描述: There are N children standing in a line. Each child is assigned a rating value.You are giving...
  • zdavb
  • zdavb
  • 2015年08月14日 17:09
  • 570

【LeetCode从零单排】No.135Candy(双向动态规划)

1.题目There are N children standing in a line. Each child is assigned a rating value.You are giving ca...
  • gshengod
  • gshengod
  • 2015年07月29日 15:14
  • 1474

135.Candy

There are N children standing in a line. Each child is assigned a rating value. You are giving ca...
  • sjt091110317
  • sjt091110317
  • 2015年07月01日 21:02
  • 692

leetcode解题报告:135. Candy

题意:There are N children standing in a line. Each child is assigned a rating value. You are giving...
  • wengyunpeng
  • wengyunpeng
  • 2016年10月02日 19:10
  • 216

135. Candy

题目大意:几个小孩站一排,每个小孩有个等级值,现在给小孩发糖,发的时候要遵守2个规则:(1)每个小孩至少一颗糖(2)两个相邻的小孩中,等级大的小孩一定比等级小的小孩糖多,求发糖的数目的最小值。对于等级...
  • wusecaiyun
  • wusecaiyun
  • 2015年08月18日 22:19
  • 174

135. Candy Leetcode Python

There are N children standing in a line. Each child is assigned a rating value. You are giving cand...
  • hyperbolechi
  • hyperbolechi
  • 2015年01月19日 21:28
  • 340

[LeetCode] 135. Candy java

/**135. Candy * @param ratings * @return */ public int candy(int[] ratings) { ...
  • u012937029
  • u012937029
  • 2017年03月09日 10:49
  • 118

【leetcode】135. Candy【java】

There are N children standing in a line. Each child is assigned a rating value. You are giving ca...
  • cslbupt
  • cslbupt
  • 2017年01月18日 09:44
  • 172

第八周——135. Candy

135. Candy
  • sysu15huangyf
  • sysu15huangyf
  • 2017年04月16日 12:04
  • 69

135. candy 贪心算法

There are N children standing in a line. Each child is assigned a rating value. You are giving ca...
  • u012985132
  • u012985132
  • 2016年09月13日 20:29
  • 283
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Hard-题目34:135. Candy
举报原因:
原因补充:

(最多只允许输入30个字)