`

【Java】产生随机数的方式小结

    博客分类:
  • Java
阅读更多

 

引用

一.在j2se里我们可以使用Math.random()方法来产生一个随机数,这个产生的随机数是0-1之间的一个double,我们可以把他乘以一定的数,比如说乘以100,他就是个100以内的随机,这个在j2me中没有。 

二.在java.util这个包里面提供了一个Random的类,我们可以新建一个Random的对象来产生随机数,他可以产生随机整数、随机float、随机double,随机long,这个也是我们在j2me的程序里经常用的一个取随机数的方法。

三.在我们的System类中有一个currentTimeMillis()方法,这个方法返回一个从1970年1月1号0点0分0秒到目前的一个毫秒数,返回类型是long,我们可以拿他作为一个随机数,我们可以拿他对一些数取模,就可以把他限制在一个范围之内啦 

其实在Random的默认构造方法里也是使用上面第三种方法进行随机数的产生的 

对于方法二中的Random类有以下说明: 

java.util.Random类有两种方式构建方式:带种子和不带种子 

不带种子: 

此种方式将会返回随机的数字,每次运行结果不一样 
Java代码   收藏代码
  1. public class RandomTest {  
  2.   
  3. public static void main(String[] args) {  
  4.   
  5. java.util.Random r=new java.util.Random();   
  6.   
  7. for(int i=0;i<10;i++){   
  8.   
  9. System.out.println(r.nextInt());  
  10.   
  11. }  
  12.   
  13. }  

带种子: 

此种方式,无论程序运行多少次,返回结果都是一样的 
Java代码   收藏代码
  1. public static void main(String[] args) {  
  2.   
  3. java.util.Random r=new java.util.Random(10);  
  4.   
  5. for(int i=0;i<10;i++){  
  6.   
  7. System.out.println(r.nextInt());  
  8.   
  9. }  
  10.   
  11. }  


两种方式的差别在于 

(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的源代码,我们可以非常明确地看到这一点。 

/** 
* Creates a new random number generator. Its seed is initialized to 
* a value based on the current time: 
* Random() { this(System.currentTimeMillis()); }java.lang.System#currentTimeMillis() 
*/ 
public Random() { this(System.currentTimeMillis()); } 

另外: 

random对象的nextInt(),nextInt(int n)方法的说明: 

int nextInt() 
返回下一个伪随机数,它是此随机数生成器的序列中均匀分布的 int 值。 

int nextInt(int n) 
返回一个伪随机数,它是从此随机数生成器的序列中取出的、在 0(包括)和指定值(不包括)之间均匀分布的 int 值 



那么,怎样产生一列不重复的随机数呢? 以产生1-12个不重复的随机数为例,网上有许多实现算法如: 

引用

算法一:用java的随机方法生成一个数字,然后mod 12,如果和前面的数值有相同的,那么抛弃这个数值,否则保存,直到数组中有12个数为止。 

算法二:定义一个数组,长度为输入的数组的长,在得到输入的整数,即其长度时进行初始化,a[0]=1,a[1]=2,a[2]=3,......,a[11]=12。然后生成的数组为b[12],用随机函数产生1到12的整数,作为a数组的下标,然后顺序赋值给b数组,赋值过的a就讲其值置为0,每次在赋值b之前检查这个a是不是0,不是则赋值,是则再得到另外一个a。这比上一个算法应该好点吧。 



这里本人提出一个简单些的算法,原理如下: 
用一个长度为12的数组保存1-12个数,如a[12]; 在一个循环中,用随机函数产生0到11的整数,如 ranX, 与-1比较,如果不相等,就输出a[ranX], 然后把a[ranX]的值设为-1, 否则进入下一循环。 

Java代码   收藏代码
  1. public void createNumber(){  
  2.        int[] randoms = {1,2,3,4,5,6,7,8,9,10,11,12};  
  3.        Random randX = new Random();  
  4.        int x = 0;  
  5.        int count = 0;  
  6.        while(count != 12) {  
  7.            x = randX .nextInt(11);  
  8.            if(randoms[x] != -1) {  
  9.                System.out.println(randoms[x]);  
  10.                randoms[x] = -1;  
  11.                count ++;  
  12.            }  
  13.        }  
  14.    }  



各位谁有更好的方法,不防写出来一起讨论...

分享到:
评论
1 楼 wml199039 2012-06-15  
random(0,12);
public int[] random(int n,int m){
        int[] result = new int[m-n];
	Random r = new Random();
	LinkedList<Integer> numbers = new LinkedList<Integer>();
	for(int i = n;i<m;i++){
		numbers.add(i);
	}
	for(int i=0;i<m-n;i++){
		result[i] = numbers.remove(r.nextInt(numbers.size()));
	}
	return result;
}


因为有LinkedList移除操作,效率可能没有你的高,但是random的次数肯定比较少

相关推荐

    javaScript产生随机数的用法小结

    var chars = ['0','1','2','3','4','5','6','7','8','9','A','B','C','D','E','F','G','H','I','J','K','L','M','N','O','P','Q','R','S','T','U','V','W','X','Y','Z']; function generateMixed(n) { ...

    Java编程实现生成给定范围内不重复随机数的方法小结

    主要介绍了Java编程实现生成给定范围内不重复随机数的方法,结合实例形式总结分析了java基于数学运算与判断实现不重复随机数的生成功能,需要的朋友可以参考下

    Java编程实现从给定范围内随机N个不重复数生成随机数的方法小结

    主要介绍了Java编程实现从给定范围内随机N个不重复数生成随机数的方法,结合实例形式较为详细的分析了java根据指定范围生成不重复随机数的相关操作技巧,需要的朋友可以参考下

    (超赞)JAVA精华之--深入JAVA API

    1.3.11 小结 1.4 java中的一些常用词汇 1.5 J2SE学习中的30个基本概念 1.6 Java线程 1.7 Java 5.0多线程编程 1.8 Java Socket编程 1.9 Java的内存泄漏 1.10 抽象类与接口的区别 1.11 Java变量类型间的相互转换 2 ...

    Java 2平台安全技术-结构,API设计和实现

    7.6.4 随机数产生算法 137 7.6.5 证书类型 137 7.6.6 密钥库类型 137 7.7 算法 137 7.7.1 SHA-1消息摘要算法 138 7.7.2 MD2消息摘要算法 138 7.7.3 MD5消息摘要算法 138 7.7.4 数字签名算法 138 7.7.5 基于RSA的签名...

    JAVA 2平台安全技术-结构,API设计和实现

    7.6.4 随机数产生算法 137 7.6.5 证书类型 137 7.6.6 密钥库类型 137 7.7 算法 137 7.7.1 SHA-1消息摘要算法 138 7.7.2 MD2消息摘要算法 138 7.7.3 MD5消息摘要算法 138 7.7.4 数字签名算法 138 7.7.5 基于RSA的签名...

    JAVA SE学习精华集锦

    1.3.11 小结 56 1.4 java中的一些常用词汇 56 1.5 J2SE学习中的30个基本概念 58 1.6 Java线程 60 1.7 Java 5.0多线程编程 65 1.8 Java Socket编程 80 1.9 Java的内存泄漏 85 1.10 抽象类与接口的区别 86 1.11 Java...

    数据结构与算法分析Java语言描述(第二版)

    算法设计技巧10.1 贪婪算法10.1.1 一个简单的调度问题10.1.2 哈夫曼编码10.1.3 近似装箱问题10.2 ...随机数发生器10.4.2 跳跃表10.4.3 素性测试10.5 回溯算法10.5.1 收费公路重建问题10.5.2 博弈小结练习参考文献第11章...

    数据结构与算法分析_Java语言描述(第2版)]

    算法设计技巧10.1 贪婪算法10.1.1 一个简单的调度问题10.1.2 哈夫曼编码10.1.3 近似装箱问题10.2 ...随机数发生器10.4.2 跳跃表10.4.3 素性测试10.5 回溯算法10.5.1 收费公路重建问题10.5.2 博弈小结练习参考文献第11章...

    数据结构与算法分析 Java语言描述第2版

    算法设计技巧10.1 贪婪算法10.1.1 一个简单的调度问题10.1.2 哈夫曼编码10.1.3 近似装箱问题10.2 ...随机数发生器10.4.2 跳跃表10.4.3 素性测试10.5 回溯算法10.5.1 收费公路重建问题10.5.2 博弈小结练习参考文献第11章...

    数据结构与算法分析_Java语言描述(第2版)

    小结 练习 参考文献 第2章 算法分析 2.1 数学基础 2.2 模型 2.3 要分析的问题 2.4 运行时间计算 2.4.1 一个简单的例子 2.4.2 一般法则 2.4.3 最大子序列和问题的求解 2.4.4 运行时间中的对数 2.4.5 检验你的分析 ...

    数据结构与算法分析_Java_语言描述

    小结 练习 参考文献 第8章 不相交集ADT 8.1 等价关系 8.2 动态等价性问题 8.3 基本数据结构 8.4 灵巧求并算法 8.5 路径压缩 8.6 按秩求并和路径压缩的最坏情形 8.7 一个应用 小结 练习 参考文献 第9章 图论...

    数据结构与算法分析-Java语言描述(第2版)_2_2

    10.3.3 最优二叉查找树 10.3.4 所有点对最短路径 10.4 随机化算法 10.4.1 随机数发生器 10.4.2 跳跃表 10.4.3 素性测试 10.5 回溯算法 10.5.1 收费公路重建问题 10.5.2 博弈 小结 练习 参考文献...

    数据结构与算法分析-Java语言描述(第2版)_1_2

    10.3.3 最优二叉查找树 10.3.4 所有点对最短路径 10.4 随机化算法 10.4.1 随机数发生器 10.4.2 跳跃表 10.4.3 素性测试 10.5 回溯算法 10.5.1 收费公路重建问题 10.5.2 博弈 小结 练习 参考文献...

    java范例开发大全源代码

    第1篇 Java编程基础  第1章 Java开发环境的搭建(教学视频:9分钟) 2  1.1 理解Java 2  1.2 搭建Java所需环境 3  1.2.1 下载JDK 3  1.2.2 安装JDK 4  1.2.3 配置环境 5  1.2.4 测试JDK配置...

    java范例开发大全

    第1篇 Java编程基础 第1章 Java开发环境的搭建(教学视频:9分钟) 2 1.1 理解Java 2 1.2 搭建Java所需环境 3 1.2.1 下载JDK 3 1.2.2 安装JDK 4 1.2.3 配置环境 5 1.2.4 测试JDK配置是否成功 7 实例1 开发第一个Java...

    Java范例开发大全 (源程序)

    第1篇 Java编程基础  第1章 Java开发环境的搭建(教学视频:9分钟) 2  1.1 理解Java 2  1.2 搭建Java所需环境 3  1.2.1 下载JDK 3  1.2.2 安装JDK 4  1.2.3 配置环境 5  1.2.4 测试JDK配置是否成功 7...

    Java开发技术大全 电子版

    1.5本章小结18 第2章Java语言基础19 2.1Java语言的特点19 2.2Java程序的构成21 2.3数据类 型23 2.3.1基本数据类型23 2.3.2常量25 2.3.3变量26 2.3.4整型数据27 .2.3.5浮点型数据29 2.3.6字符型数据30 ...

Global site tag (gtag.js) - Google Analytics