我正在尝试生成一个整数数组,其中包含随机数加起来一个特定的值。这是我的代码:
private long[] getRandoms(long size , long sum) throws Exception {
double iniSum = 0;
System.out.println("sum = " + sum);
long[] ret = new long[(int) size];
for (int i = 0 ; i < ret.length; i++) {
ret[i] = randomInRange(1, sum);
iniSum += ret[i];
}
double finSum = 0;
for (int i = 0 ; i < ret.length; i++) {
ret[i] = Math.round((sum * ret[i]) / iniSum);
System.out.println("ret[" + i +"] = " + ret[i]);
finSum += ret[i];
}
if (finSum != sum) throw new Exception("Could not find " + size + " numbers adding up to " + sum + " . Final sum = " + finSum);
return ret;
}
private long randomInRange(long min , long max) {
Random rand = new Random();
long ret = rand.nextInt((int) (max - min + 1)) + min;
System.out.println("ret = " + ret);
return ret;
}
但是,结果并不准确,例如:
找不到 4194304 的 100 个数字。最终总和 = 4194305.0
我认为我在这一点上失去了准确性:
(sum * ret[i]) / iniSum
您能否在我的代码中推荐一种替代算法或修复方法来帮助我实现这一目标?