• 动手动脑四


    获得随机数
    for (int i=0;i<30;i++)
    {System.out.println((int)(1+Math.random()*10));}
    (int)(1+Math.random()*10)
    通过java.Math包的random方法得到1-10的int随机数
    公式是:最小值---最大值(整数)的随机数
    (类型)最小值+Math.random()*最大值

    种子和不带种子

    不带种子:
    此种方式将会返回随机的数字,每次运行结果不一样

    public class RandomTest {
    public static void main(String[] args) {
    java.util.Random r=new java.util.Random();
    for(int i=0;i<10;i++){
        System.out.println(r.nextInt());
    }

    }
    带种子:
    此种方式,无论程序运行多少次,返回结果都是一样的

    public static void main(String[] args) {
    java.util.Random r=new java.util.Random(10);
    for(int i=0;i<10;i++){
        System.out.println(r.nextInt());
    }
    }

    两种方式的差别在于

    (1) 首先请打开Java Doc,我们会看到Random类的说明:

    此类的实例用于生成伪随机数流,此类使用 48 位的种子,该种子可以使用线性同余公式对其进行修改(请参阅 Donald Knuth 的《The Art of Computer Programming, Volume 2》,第 3.2.1 节)。

    如果用相同的种子创建两个 Random 实例,则对每个实例进行相同的方法调用序列,它们将生成并返回相同的数字序列。为了保证实现这种特性,我们为类Random指定了特定的算法。为了 Java 代码的完全可移植性,Java 实现必须让类 Random 使用此处所示的所有算法。但是允许 Random 类的子类使用其他算法,只要其符合所有方法的常规协定即可。

    Java Doc对Random类已经解释得非常明白,我们的测试也验证了这一点。

    (2) 如果没有提供种子数,Random实例的种子数将是当前时间的毫秒数,可以通过System.currentTimeMillis()来获得当前时间的毫秒数。打开JDK的源代码,我们可以非常明确地看到这一点。

  • 相关阅读:
    2018年9月28日CCPC秦皇岛站参赛总结
    数学:二次剩余与n次剩余
    数学:拓展Lucas定理
    BZOJ2301:莫比乌斯反演+二维容斥解决GCD范围计数
    数学:莫比乌斯反演-约数个数和
    数学:莫比乌斯反演-GCD计数
    关于cnblogs至github上blog的搬迁
    友链——一群dalao
    折半搜索(meet in the middle)
    关于爆搜
  • 原文地址:https://www.cnblogs.com/xc166/p/5984912.html
Copyright © 2020-2023  润新知