LeetCode 135. 分发糖果

n 个孩子站成一排。给你一个整数数组 ratings 表示每个孩子的评分。

你需要按照以下要求,给这些孩子分发糖果:

  • 每个孩子至少分配到 1 个糖果。
  • 相邻两个孩子评分更高的孩子会获得更多的糖果。

请你给每个孩子分发糖果,计算并返回需要准备的 最少糖果数目

示例 1:

复制代码
输入:ratings = [1,0,2]
输出:5
解释:你可以分别给第一个、第二个、第三个孩子分发 2、1、2 颗糖果。

示例 2:

复制代码
输入:ratings = [1,2,2]
输出:4
解释:你可以分别给第一个、第二个、第三个孩子分发 1、2、1 颗糖果。
     第三个孩子只得到 1 颗糖果,这满足题面中的两个条件。

提示:

  • n == ratings.length
  • 1 <= n <= 2 *
  • 0 <= ratings[i] <= 2 *

思路:

本题可采用贪心思路确定每个孩子的糖果数。

先从左向右比,最左边的孩子的糖果数为 1,如果右边的孩子的评分高于左边的孩子则给右边孩子的糖果数为左孩子的糖果数+1,若右边的孩子评分不高于左边的孩子,则给一个糖果。这样会让比左边的孩子评分高的孩子得到更多的糖果。此时也初步形成了当前糖果分配数组 candyNums 。

再从右往左比,如果左边的孩子的评分高于右边的孩子的评分,则 左边的孩子所分得的糖果数为 当前糖果数(用于保底,如果 右边的孩子的糖果数+1< 当前糖果数,则当前糖果数不变,这时可以满足之前从左往右比确定的条件,又可以满足大于右边孩子糖果数的条件)右边的孩子的糖果数+1(保证左边的孩子的糖果大于右边的孩子) 两者之间的最大值(此时既满足从左往右确定的条件,又满足从右往左确定的条件)。

代码:

复制代码
class Solution {
    public int candy(int[] ratings) {
        int len = ratings.length;
        int[] candyNums = new int[len];
        candyNums[0]=1;
        for(int i=1;i<len;i++){
            if(ratings[i]>ratings[i-1]){
                //从左往右比,如果右边的孩子评分高于左边的孩子,则右边的孩子糖果数比左边的孩子多一个
                candyNums[i]=candyNums[i-1]+1;
            }
            else{
                //否则给一个糖果
                candyNums[i]=1;
            }
        }
        //从右往左比,如果左边的孩子评分高于右边的孩子,则左边的孩子分得的糖果数为
        //当前糖果数与右边孩子糖果数+1 两者之间的最大值(为了保证比左右孩子都评分高的孩子的糖果数比左右孩子都多)
        for(int i=len-2;i>=0;i--){
            if(ratings[i]>ratings[i+1]){
                candyNums[i] = Math.max(candyNums[i],candyNums[i+1]+1);
            }
        }
        int ans = 0;
        for(int x:candyNums){
            ans += x;
        }
        return ans;
    }
}

参考:代码随想录

相关推荐
浩浩测试一下1 小时前
06高级语言逻辑结构到汇编语言之逻辑结构转换 for (...; ...; ...)
汇编·数据结构·算法·安全·web安全·网络安全·安全架构
辞--忧2 小时前
K-Means 聚类算法详解与实战指南
算法·kmeans·聚类
尤超宇2 小时前
K 均值聚类(K-Means)演示,通过生成笑脸和爱心两种形状的模拟数据,展示了无监督学习中聚类算法的效果。以下是详细讲解:
算法·均值算法·聚类
qq_479875432 小时前
设置接收超时(SO_RCVTIMEO)
c语言·算法
li星野2 小时前
打工人日报#20250824
程序人生·职场和发展·学习方法·程序员创富
张同学的IT技术日记2 小时前
【奇妙的数据结构世界】用图像和代码对堆栈的使用进行透彻学习 | C++
算法
野生的编程萌新4 小时前
【数据结构】从基础到实战:全面解析归并排序与计数排序
数据结构·算法·排序算法
Mercury_Lc4 小时前
【链表 - LeetCode】206. 反转链表【带ACM调试】
算法·链表
YuTaoShao4 小时前
【LeetCode 热题 100】152. 乘积最大子数组——(解法一)递推
java·算法·leetcode·职场和发展
weixin_307779135 小时前
C++进程监视器与自动启动程序
开发语言·c++·算法