首页 > 其他 > 详细

9.24动手动脑

时间:2019-09-28 20:13:17      阅读:100      评论:0      收藏:0      [点我收藏+]

请看以下代码,你发现了有什么特殊之处吗?

技术分享图片

 

 这段代码定义了重载函数,所以两个输出里面的函数名一样,但运行的结果不一样。

 

编写一个方法,使用以上算法生成指定数目(比如1000个)的随机整数。

技术分享图片

 

 

Modulus=231-1=int.MaxValue Multiplier=75=16807 C=0 当显示过231-2个数之后,才可能重复。

public class suiji
{
private static final int N = 200;
private static final int LEFT = 40;
private static final int RIGHT = 10000;
private static long x0 = 1L;
private long a = 1103515245L;
private long c = 12345L;
private long m = 2147483648L;

// 产生随机数
private long rand ( long r )
{
// a,c,m为常数
r = ( r * a + c ) % m;//Xn+1=(aXn + c)mod m
return r;
}

* 表示a~b之间的一个随机数
private long little ( int a, int b, long rand )
{
return a + rand % ( b - a + 1 );
}

private void recursion ( int count, long rand )
{
if (count >= N)
{
return;
}
rand = rand (rand);
long r = little (LEFT, RIGHT, rand);
System.out.print (r + " ");
recursion (++count, rand);
}

public static void main ( String[] args )
{
suiji recur = new suiji ();
recur.recursion (0, x0);
}
}

 

9.24动手动脑

原文:https://www.cnblogs.com/2940500426yingxin/p/11604624.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!