
根据总数生成随机数的优化方法
在讨论中提到的方法面临着一个问题:当总数大于随机数总和时,最后生成的框值会变成负数。为了解决这个问题,我们可以对方法进行优化。
优化后的方法:
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;
}优化要点:
- 每次循环计算 step,确保 step 在剩下的数据中平均分配。
- 每次更新 value 时,确保 value 不超过总数 num。










