登录
首页 >  文章 >  前端

如何用JavaScript根据总数和分组大小生成平均分配的随机数?

时间:2025-03-16 11:16:26 154浏览 收藏

本文介绍一种JavaScript算法,解决如何将指定数量的随机数平均分配到不同大小的分组中的问题。 传统算法存在分配不均或出现负数的缺陷,而本文提供的改进算法通过`Math.floor()`函数进行下取整,并动态更新剩余随机数和分组数量,确保平均分配。该算法不仅能计算每个分组应分配的随机数数量,还可选地生成指定范围内的实际随机数,有效避免了原始算法的错误,实现更精准的随机数平均分配。 学习此算法,您可以轻松高效地处理随机数分组问题。

如何用JavaScript根据总数和分组大小生成平均分配的随机数?

本文介绍一种JavaScript算法,用于根据总数和分组大小生成平均分配的随机数。 该算法旨在解决将指定数量的随机数平均分配到不同大小的分组中的问题,避免原始算法中出现负数或分配不均的情况。

问题描述:给定一个数组arr,其中每个对象包含一个test属性表示分组大小,以及一个总数num,需要生成num个随机数并平均分配到各个分组中。

原始算法存在的问题:原始算法在计算每个分组的随机数范围时,存在逻辑错误,导致分配不均或出现负数。

改进后的算法:

以下代码提供了一种改进的算法,解决了原始算法中的问题:

function distributeRandomNumbers(list, num = 29) {
    const data = list.map((item) => 
        Array.from({ length: Number(item.test) }).map(() => ({ min: 0, max: 0, num: 0 }))
    );

    let count = list.reduce((sum, item) => sum + Number(item.test), 0);
    let remainingNumbers = num;

    for (let i = 0; i < list.length; i++) {
        const groupSize = Number(list[i].test);
        let numbersPerGroup = Math.floor(remainingNumbers / count); // 下取整,保证平均分配

        if (count <= groupSize){
            numbersPerGroup = Math.floor(remainingNumbers / count);
        }

        for (let j = 0; j < groupSize && remainingNumbers > 0; j++) {
            data[i][j].num = numbersPerGroup;
            remainingNumbers -= numbersPerGroup;
        }
        count -= groupSize;
    }

    //  (可选)  如果需要生成实际的随机数,而不是数量,可以添加如下代码:
    // for (let i = 0; i < data.length; i++) {
    //     for (let j = 0; j < data[i].length; j++) {
    //         data[i][j].num = Math.floor(Math.random() * 100); // 生成0-99之间的随机数, 可根据需要调整范围
    //     }
    // }

    return data;
}

改进的核心在于:

  1. 平均分配策略: 使用 Math.floor(remainingNumbers / count) 计算每个分组应分配的随机数数量,并进行下取整,确保平均分配。
  2. 动态更新: 在循环中动态更新 remainingNumberscount,以准确反映剩余随机数和分组数量。

这个改进后的算法能够更有效地将随机数平均分配到各个分组中,避免了原始算法中的错误。 最后,代码中还包含可选部分,用于生成实际的随机数,而不是仅仅分配数量。 用户可以根据需求选择是否启用此部分代码。

以上就是《如何用JavaScript根据总数和分组大小生成平均分配的随机数?》的详细内容,更多关于的资料请关注golang学习网公众号!

相关阅读
更多>
最新阅读
更多>
课程推荐
更多>