根据总数生成随机数的javascript实现优化
本文将探讨如何根据一个给定的总数,结合已有的数据结构,生成一系列随机数,并对原代码中出现的负数问题进行优化。 问题源于需要根据数组arr中每个对象的test属性值(表示数据列数),生成一定数量(总数为29)的随机数,并将其分配到对应的列中。原代码在处理总数分配时出现溢出,导致部分随机数出现负值。
原代码的核心问题在于对value的更新方式。 if(num
改进后的代码通过调整步长step的计算方式,避免了这个问题。 新的代码采用了下取整运算符| 0 来计算step,并每次迭代都递减count以及num,确保step在剩余总数中平均分配。 这样,在每个迭代中,step都会根据剩余总数进行调整,避免了之前代码中由于value的提前截断而造成的分配不均问题。
以下是优化后的代码:
立即学习“Java免费学习笔记(深入)”;
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; }
通过这种改进,确保了每个随机数的范围都在合理的区间内,避免了负数的产生,更有效地解决了根据总数生成随机数的问题。
以上就是如何优化JavaScript中根据总数生成随机数,避免负数出现?的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号