关闭

Hard-题目34:135. Candy

125人阅读 评论(0) 收藏 举报
分类:

题目原文:
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里面找题了。

0
0

猜你在找
【套餐】Hadoop生态系统零基础入门
【套餐】嵌入式Linux C编程基础
【套餐】2017软考系统集成项目——任铄
【套餐】Android 5.x顶级视频课程——李宁
【套餐】深度学习入门视频课程——唐宇迪
【直播】广义线性模型及其应用——李科
【直播】从0到1 区块链的概念到实践
【直播】计算机视觉原理及实战——屈教授
【直播】机器学习之凸优化——马博士
【直播】机器学习&数据挖掘7周实训--韦玮
查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:55443次
    • 积分:3193
    • 等级:
    • 排名:第10669名
    • 原创:270篇
    • 转载:53篇
    • 译文:0篇
    • 评论:7条
    文章分类
    最新评论