繁体   English   中英

有没有办法获得随机整数的 Math.min() ? 爪哇

[英]Is there a way to get the Math.min() for random integers? Java

我目前正在制作一个游戏,我正在尝试比较屏幕上显示的最短路径(这是一个随机生成的整数路径)和用户采用的路径。 这部分代码是我尝试在屏幕上获取总路径的Math.min()部分:

int path1 = randomNum3 + randomNum8;
int path2 = randomNum2 + randomNum7;
int path3 = randomNum + randomNum6;
int path4 = randomNum3 + randomNum5 + randomNum7;
int path5 = randomNum2 + randomNum5 + randomNum8;
int path6 = randomNum + randomNum4 + randomNum7;
int path7 = randomNum2 + randomNum4 + randomNum6;


int caminoMasCorto = Math.min(path1, path2, path3, path4, path5,
        path6, path7);

向我展示的错误是这个:

没有找到适合 min(int,int,int,int,int,int,int) 的方法

方法 Math.min(int,int) 不适用

(实际和形式参数列表的长度不同)

是的。 正如错误所说, Math.min(int, int)需要两个参数。 改变

int caminoMasCorto = Math.min(path1, path2, path3, path4, path5,
        path6, path7);

int caminoMasCorto = Math.min(path1, Math.min(path2, 
        Math.min(path3, Math.min(path4, Math.min(path5, Math.min(path6, path7))))));

(正如安德烈亚斯所指出的)

int caminoMasCorto = Math.min(Math.min(Math.min(Math.min(Math.min(Math.min(
        path1, path2), path3), path4), path5), path6), path7);

或者,您可以编写自己的min函数,该函数接受任意数量的int (s) 并返回最小值。 喜欢,

private static int myMin(int... vals) {
    if (vals == null || vals.length < 1) {
        throw new RuntimeException("No values");
    }
    int t = vals[0];
    for (int i = 1; i < vals.length; i++) {
        t = Math.min(t, vals[i]);
    }
    return t;
}

然后使用

int caminoMasCorto = myMin(path1, path2, path3, path4, path5,
        path6, path7);

使用您认为最易读的任何一个。

要找到大量int变量中的最小值,请使用:

int caminoMasCorto = IntStream.of(path1, path2, path3, path4, path5,
        path6, path7).min().getAsInt();

如果您不使用 Java 8+,则可以执行以下操作:

int caminoMasCorto = path1;
for (int value : new int[] { path2, path3, path4, path5, path6, path7 })
    caminoMasCorto = Math.min(caminoMasCorto, value);

Java 的Math.min接受两个参数。 要将其扩展到多个数字,请尝试以下方法:

public int minExtension (int... numbers) {
    int minimum = numbers[0];

    for (int number : numbers) {
        minimum = Math.min(number, minimum)
    }

    return minimum
}

像这样称呼

int caminoMasCorto = minExtension (path1, path2, path3, path4, path5, path6, path7);

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM