zoukankan      html  css  js  c++  java
  • candy(贪心)

    【题目】

    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?

    【题意】

    多个小朋友站成一排,根据他们的得分分发糖果,得分高的小朋友要比旁边得分低的小朋友得到的糖果多,每个小朋友至少得到一枚糖果,问最少要准备多少糖果?

    【思路】

    先从左到右扫描一遍,使得右边比左边得分高的小朋友糖果数比左边多。

    再从右到左扫描一遍,使得左边比右边得分高的小朋友糖果数比右边多。

    使用贪心算法。使用一个数组存储每个小孩获得的糖果。因为要保证rating大的分的的糖果比两边都高。
    两次遍历ratings数组,第一次从前往后遍历,使得右边比左边得分高的孩子分得的糖果多一个(因为要最少糖果)。其他的如后面比前面小的就都初始化为1。然后从后往前遍历,如果前面比后面得分高,但是前面的糖果数却没有后面高,那么前面的糖果数就是后面的糖果数+1,保证左边比右边得分高的小朋友分得的糖果多。

    class Solution {
        public int candy(int[] ratings) {
            
            if(ratings.length==1) return 1;
            //使用一个数组表示每个孩子分得的糖果数
            int[] helper=new int[ratings.length];
            //先初始化数组,给每个孩子一个糖果(题目说至少要一个)
            for(int i=0;i<ratings.length;i++) helper[i]=1;
            //从左往右遍历,如果后面比前面孩子得分高,那么后面的糖果加1,使得后面得分高的孩子分得的糖果也多。
            for(int i=1;i<ratings.length;i++){
                if(ratings[i]>ratings[i-1]){
                    
                    helper[i]=helper[i-1]+1;
                   
                }
            }
            //上面只保证了右边得分高时右边的糖果多,么有保证左边得分高时它的糖果也多。
            //这里从后往前遍历,保证左边得分高的孩子,它的糖果也比右边多。如果左边比右边得分高,但是左边分得的糖果没有比右边多,那就给左边分糖果,是右边的加1.
            for(int i=ratings.length-1;i>0;i--){
                if(ratings[i-1]>ratings[i]&&helper[i-1]<=helper[i]){
                    helper[i-1]=helper[i]+1;
                }
            }
            
            int sum=0;
            for(int i=0;i<ratings.length;i++){
                sum+=helper[i];
            }
            return sum;
        }
    }
  • 相关阅读:
    设计模式之策略模式、观察者模式浅析
    axis2_1.6.2之构建web端和客户端
    EJB3之查询
    qpid之简单实例
    ant1.9.4之编译、打包、发布、清理
    四数之和
    电话号码的字母的组合
    最接近的三数之和
    三数之和
    最长公共前缀
  • 原文地址:https://www.cnblogs.com/xiaolovewei/p/8334502.html
Copyright © 2011-2022 走看看