java - 如何在数组中生成随机数,使其总和达到定义的总数?

标签 java arrays algorithm random

我需要在 Java 中随机生成一个有 7 个槽的数组。所有这些插槽的值必须至少为 1,但合并后的总值为另一个定义的数字。它们也都需要是一个 int 值,没有 1.5 或 0.9816465684646 数字。 示例:

int a=10;

int[] ar = new int[7]
ar[0] = 1
ar[1] = 1
ar[2] = 2
ar[3] = 2
ar[4] = 1
ar[5] = 2
ar[6] = 1

我希望它生成类似的东西,但如果 int a=15,所有数字的总和将以任意顺序为 15

最佳答案

生成 N 个随机数并添加到给定总和的标准方法是将您的总和视为一条数字线,在线上生成 N-1 个随机点,对它们进行排序,然后使用这些点之间的差异作为您的最终值。要获得最小值 1,首先从总和中减去 N,运行给定的算法,然后将 1 加回每个段。

public class Rand {
    public static void main(String[] args) {
        int count = 8;
        int sum = 100;
        java.util.Random g = new java.util.Random();

        int vals[] = new int[count];
        sum -= count;

        for (int i = 0; i < count-1; ++i) {
            vals[i] = g.nextInt(sum);
        }
        vals[count-1] = sum;

        java.util.Arrays.sort(vals);
        for (int i = count-1; i > 0; --i) {
            vals[i] -= vals[i-1];
        }
        for (int i = 0; i < count; ++i) { ++vals[i]; }

        for (int i = 0; i < count; ++i) {
            System.out.printf("%4d", vals[i]);
        }
        System.out.printf("\n");
    }
}

关于java - 如何在数组中生成随机数,使其总和达到定义的总数?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18600348/

相关文章:

algorithm - 如何找出时间复杂度是指数的?

java - 有人看到我的更新或插入查询有问题吗?我正在使用准备好的声明

java - 查找二维网格中物体距离的百分比

使用 Int 的 Java jSF NamedQuery

Javascript 将项目组合到数组对象中

php - PHP mySQL 的条件 in_array 问题

带条件的 Python 排列(回溯)

algorithm - Quick sort中三分区的Median是如何提高5%左右效率的?

Java 文件转为 upperCase 和 lowerUpper

java - GridView 上的 TextView 以及项目数