算法-遍历分发糖果

hello 大家好!今天开写一个新章节,每一天一道算法题。让我们一起来学习算法思维吧!

javascript 复制代码
function candy(ratings) {
    // 获取孩子的数量
    const n = ratings.length;
    // 初始化一个长度为 n 的数组 candies,用于存储每个孩子分配到的糖果数,初始每个孩子至少有 1 颗糖果
    const candies = new Array(n).fill(1);

    // 从左到右遍历孩子的评分数组
    for (let i = 1; i < n; i++) {
        // 如果当前孩子的评分比前一个孩子高
        if (ratings[i] > ratings[i - 1]) {
            // 那么当前孩子的糖果数要比前一个孩子多 1 颗
            candies[i] = candies[i - 1] + 1;
        }
    }

    // 从右到左遍历孩子的评分数组
    for (let i = n - 2; i >= 0; i--) {
        // 如果当前孩子的评分比后一个孩子高
        if (ratings[i] > ratings[i + 1]) {
            // 取当前孩子已分配的糖果数和后一个孩子糖果数加 1 中的较大值
            // 这样能保证既满足从左到右的规则,也满足从右到左的规则
            candies[i] = Math.max(candies[i], candies[i + 1] + 1);
        }
    }

    // 计算所有孩子分配到的糖果总数
    let totalCandies = 0;
    for (let i = 0; i < n; i++) {
        totalCandies += candies[i];
    }

    return totalCandies;
}

// 示例测试
const ratings = [1, 0, 2];
console.log(candy(ratings)); 

代码解释

整体思路

本题要求给孩子们分糖果,需要满足每个孩子至少有 1 颗糖果,并且相邻孩子中评分高的孩子获得更多糖果。为了满足这些条件,我们可以采用两次遍历的方法:

第一次从左到右遍历,保证每个孩子如果比其左边孩子评分高,那么他的糖果数比左边孩子多。

第二次从右到左遍历,保证每个孩子如果比其右边孩子评分高,那么他的糖果数比右边孩子多。同时在这个过程中要取满足两次遍历规则的最大值。

最后将每个孩子的糖果数累加起来,得到最少需要准备的糖果总数。

代码步骤分析

初始化:

n:获取孩子的数量,方便后续操作。

candies:创建一个长度为 n 的数组,初始每个元素都为 1,表示每个孩子至少分配到 1 颗糖果。

从左到右遍历:

从第二个孩子(索引为 1)开始遍历到最后一个孩子。

若当前孩子评分比前一个孩子高,则当前孩子的糖果数为前一个孩子糖果数加 1。

从右到左遍历:

从倒数第二个孩子(索引为 n - 2)开始遍历到第一个孩子。

若当前孩子评分比后一个孩子高,则当前孩子的糖果数取当前值和后一个孩子糖果数加 1 中的较大值。这样可以同时满足从左到右和从右到左的规则。

计算总数:

遍历 candies 数组,将每个孩子的糖果数累加起来,得到最少需要准备的糖果总数。

相关推荐
_志哥_8 分钟前
深度解析:解决 backdrop-filter 与 border-radius 的圆角漏光问题
前端·javascript·html
qiao若huan喜26 分钟前
10、webgl 基本概念 + 坐标系统 + 立方体
前端·javascript·信息可视化·webgl
不当菜鸡的程序媛37 分钟前
Flow Matching|什么是“预测速度场 vt=ε−x”?
人工智能·算法·机器学习
sali-tec1 小时前
C# 基于halcon的视觉工作流-章58-输出点云图
开发语言·人工智能·算法·计算机视觉·c#
_OP_CHEN1 小时前
算法基础篇:(四)基础算法之前缀和
c++·算法·前缀和·蓝桥杯·acm·icpc·算法竞赛
_OP_CHEN1 小时前
算法基础篇:(五)基础算法之差分——以“空间”换“时间”
c++·算法·acm·icpc·算法竞赛·差分算法·差分与前缀和
DuHz1 小时前
霍夫变换和基于时频脊线的汽车FMCW雷达干扰抑制——论文阅读
论文阅读·物联网·算法·汽车·信息与通信·毫米波雷达
秋风&萧瑟1 小时前
【C++】智能指针介绍
java·c++·算法
QiZhang | UESTC1 小时前
JAVA算法练习题day67
java·python·学习·算法·leetcode
摸着石头过河的石头1 小时前
Service Worker 深度解析:让你的 Web 应用离线也能飞
前端·javascript·性能优化