根据总数生成随机数的优化方法
在讨论中提到的方法面临着一个问题:当总数大于随机数总和时,最后生成的框值会变成负数。为了解决这个问题,我们可以对方法进行优化。
优化后的方法:
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。