贪心算法解决分发糖果问题

代码随想录链接: 代码随想录

思路:

由于每个孩子都要得到一块糖果,因此初始化一个全为1的数组,该数组的长度等于孩子的个数

从前往后遍历,如果位置i处的孩子对应的分数大于位置i-1处的孩子的分数,令该孩子 获得的糖果数量为位置i-1 处孩子获得的糖果数量+1

从后往前遍历数组中的每个元素,如果位置i处的孩子 对应的分数大于 位置i+1处的孩子 的分数,令该孩子 获得的糖果数量为位置i+1处孩子糖果数量+1原先该孩子获得的糖果数量最大值

两次遍历结束后,统计数组中的每个元素之和,即表示获得的最终结果

代码:

java 复制代码
class Solution {
    /**
         分两个阶段
         1、起点下标1 从左往右,只要 右边 比 左边 大,右边的糖果=左边 + 1
         2、起点下标 ratings.length - 2 从右往左, 只要左边 比 右边 大,此时 左边的糖果应该 取本身的糖果数(符合比它左边大) 和 右边糖果数 + 1 二者的最大值,这样才符合 它比它左边的大,也比它右边大
    */
    public int candy(int[] ratings) {
        int len = ratings.length;
        int[] candyVec = new int[len];
        candyVec[0] = 1;
        for (int i = 1; i < len; i++) {
            candyVec[i] = (ratings[i] > ratings[i - 1]) ? candyVec[i - 1] + 1 : 1;
        }

        for (int i = len - 2; i >= 0; i--) {
            if (ratings[i] > ratings[i + 1]) {
                candyVec[i] = Math.max(candyVec[i], candyVec[i + 1] + 1);
            }
        }

        int ans = 0;
        for (int num : candyVec) {
            ans += num;
        }
        return ans;
    }
}
相关推荐
奇偶变不变13 分钟前
RTOS之事件集
java·linux·jvm·单片机·算法
Sunsets_Red17 分钟前
CF1548A Web of Lies 题解
c++·学习·算法·信息与通信
Solitudefire37 分钟前
蓝桥杯刷题——day7
算法·蓝桥杯
了一li1 小时前
MATLAB转换C语言--问题(一)FFT 和 IFFT 的缩放因子
算法
古希腊掌管学习的神2 小时前
[机器学习] 决策树
python·算法·决策树·机器学习
呆呆的猫3 小时前
【LeetCode】726、原子的数量
算法·leetcode·职场和发展
莫叫石榴姐3 小时前
SQL进阶技巧:如何计算算法题分发糖果问题?
大数据·数据结构·数据库·sql·算法·数据挖掘·数据分析
arnold663 小时前
华为OD E卷(100分)25-整数对最小和
算法·华为od
arnold663 小时前
华为OD E卷(100分)32-字符串分割
算法·华为od
木向4 小时前
leetcode46全排列
数据结构·算法