我在想是否有办法生成一组总和始终为常数的随机数。例如,20 可以分为 5 个数字(1、2、3、4、10)我不在乎这 5 个数字中的每一个是什么,只要它们的总和等于 20。无论如何以编程方式这样做?
最佳答案
要获得均匀分布,诀窍是将您的总和视为一条数轴,而不是为线段生成随机数,而是生成 n-1 个数字作为沿线的点,然后减去以获得线段。这是来自 ojrandlib 的函数:
static int compare(const void *a, const void *b) {
return *(int*)a - *(int*)b;
}
void ojr_array_with_sum(ojr_generator *g, int *a, int count, int sum) {
int i;
for (i = 0; i < count-1; ++i) { a[i] = ojr_rand(g, sum+1); }
qsort(a, count-1, sizeof(int), compare);
a[count-1] = sum;
for (i = count-1; i > 0; --i) { a[i] -= a[i-1]; }
}
ojr_rand(g, limit)
生成一个从 0 到 limit-1 的均匀随机整数。这个函数然后填充数组 a
与 count
添加到 sum
的随机整数.将此适应任何其他 RNG 应该不会太难。
关于random - 生成总和为常数的随机数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16883419/