`

【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产生随机数的用法小结

    这里,`Math.random()` 后的计算方式同上,但使用 `Math.round()` 四舍五入,结果可能是0(0.49及以下)或1到10(0.5到0.999...)。 如果需要生成指定范围内的随机数,可以使用如下的通用函数: ```javascript ...

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

    Java编程实现生成给定范围内不重复随机数的方法小结 Java编程实现生成给定范围内不重复随机数的方法是非常重要的一种技术,本文将主要介绍Java编程实现生成给定范围内不重复随机数的方法,结合实例形式总结分析了...

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

    首先,我们来了解一下Java中生成随机数的基本方式: 1. 使用`Math.random()`函数:这个方法会返回一个0.0到1.0之间(不包括1.0)的double类型随机数。可以通过将其乘以一个范围并转换为整数来得到特定范围内的...

    core java 小结

    补码是计算机内部表示整数的一种方式,主要为了简化运算。补码的使用涉及正溢出和负溢出的概念,以及大整数运算如`BigInteger`的使用。符号扩展和无符号扩展也是理解补码的关键,而移位操作如右移(`&gt;&gt;`)、左移(`)和...

    java试题小结可以下载的

    【Java试题小结】 1. **Applet生命周期与方法**: - 在Java中,Applet的生命周期包括初始化、启动、绘画、停止和销毁几个阶段。`init()`方法用于初始化Applet所需资源,`paint()`方法负责在屏幕上绘制图形,如线条...

    实验5 JAVA常用类.doc

    实验5的Java常用类主要涵盖了Java编程中的一些核心概念和常用工具类的使用。以下是这些知识点的详细说明: 1. **String、StringBuffer(StringBuilder)**: - **String** 类在Java中是不可变的,这意味着一旦创建了...

    第11章抽奖——随机数与枚举.ppt

    **11.5 本章小结** 本章内容总结了如何生成随机数,使用`Random`类以及可变参数方法。同时,引入了枚举类型作为编程中的常量集合,有助于构建更结构化的抽奖程序。通过学习这些知识,开发者可以创建出具有真实随机...

    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贪吃蛇项目(含实验报告)

    【描述】"java结课项目"表明这是一项课程作业,可能是在学习Java编程课程的后期阶段,学生们被要求独立或团队合作完成的。这样的项目通常要求学生将课堂上学习的面向对象编程概念、事件处理、图形用户界面(GUI)...

    猜数字小游戏JAVA程序报告.doc

    我们可以借助 Java API 提供的 Random 类来产生一个随机数。首先在 main 函数中加入以下代码:Random random = new Random(); number = (100); 2.输入判断模块 在游戏界面中输入不合法 try {guess = ());} catch ...

    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的签名...

    JavaModbus的操作(实例).pdf

    6. 小结 在本实例中,我们实现了JavaModbus的操作流程,并详细介绍了其实现细节。通过本实例,我们可以了解JavaModbus的工作原理和实现细节,并在实际项目中应用JavaModbus来实现Modbus协议的通讯操作。

    java实验--贪心猪小游戏、输入输出流、图形化界面、图书系统.docx

    #### 实验一:贪心猪小游戏 **实验目的:** - 掌握Java语言的基础编程能力,特别是在Eclipse平台上的实践应用。 - 学习如何使用控制流语句(如if、while)和随机数生成方法(如`Math.random()`)。 - 熟悉类的声明...

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

    - **小结** - Java 的 I/O 包提供了丰富的类来处理文件和流,包括基本的字节流、字符流、文件流、缓冲流等。 **1.4 Java中的一些常用词汇** - **术语解释** - 如继承、封装、多态等。 **1.5 J2SE学习中的30个...

    事件编程小结

    ### 事件编程小结 在Java中,事件处理机制是一种非常重要的编程模型,尤其是在图形用户界面(GUI)设计中。事件编程允许程序响应用户的输入,如点击按钮、移动鼠标等。本文将详细介绍Java中的事件处理机制,特别是...

    java实验报告

    【Java实验报告】 Java实验报告主要涵盖了两个核心实验:JDK的安装与配置以及简单的程序编写,以及理解和使用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章...

Global site tag (gtag.js) - Google Analytics