
根据总数生成随机数的优化方法
在讨论中提到的方法面临着一个问题:当总数大于随机数总和时,最后生成的框值会变成负数。为了解决这个问题,我们可以对方法进行优化。
优化后的方法:
function filterate(list, num = 29) {
let data = list.map((item, index) => {
return Array.from({ length: Number(item.test) }).map(citem => {
return {
min: 0,
max: 0,
num: 0,
};
});
});
let max = Math.max(...list.map(i => Number(i.test)));
let value = 0;
let current = 1;
let count = list.reduce((n, i) => n + Number(i.test), 0);
for (let index = 0; index < max; index++) {
data.forEach((item, k) => {
if (item[index]) {
let step = num / count | 0; // 下取整
count--; // 循环计算 step,确保 step 在剩下的数据中平均分配
num -= step;
item[index].min = value + 1;
value += step;
item[index].max = value;
item[index].num =
Math.floor(Math.random() * (item[index].max - item[index].min + 1)) +
item[index].min;
}
});
}
return data;
}优化要点:
以上就是如何优化根据总数生成随机数避免出现负数结果?的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号