介绍JAVA随机数的几种方法

开发 后端
本文介绍的是java获取随机数的几种方法,希望对你有帮助,一起来看。

JAVA随机数的几种方法:

 

方法1:

 

 

  1. //利用固定数组长度n,通过n的变化来实现。  
  2. //关键:nums[r]=nums[n-1];  
  3. // n--;  
  4. public class Test1  
  5. {  
  6. public static void main(String[] args){  
  7. int n=35;  
  8. int[] nums=new int[n];  
  9. for(int i=0;i<nums.length;i++)  
  10. nums[i]=i+1;  
  11. int[] arr=new int[7];  
  12. for(int i=0;i<arr.length;i++){  
  13. int r=(int)(Math.random()*n);  
  14. arr[i]=nums[r];  
  15. nums[r]=nums[n-1];  
  16. n--;  
  17. }  
  18. for(int i=0;i<arr.length;i++){  
  19. System.out.print(arr[i]+" ");  
  20. }  
  21. }  

 

 

 

方法2:

 

  1. //利用循环实现  
  2. public class Test2   
  3. {   
  4. public static void main(String[] args){   
  5. int[] arr = new int[7];   
  6. for (int i = 0; i < 7; i++){   
  7. arr[i] = (int) (Math.random() * 35) + 1;   
  8. for (int j=0; j<i;j++){   
  9. if (arr[j] == arr[i]){//如果arr[i]与arr[j]相同,则arr[i]重新取值,并检验  
  10. i--;  
  11. break;  
  12. }  
  13. }  
  14. }  
  15. for(int i=0;i<7; i++)   
  16. System.out.print(arr[i] + " ");   
  17. }  

 

 

 

方法3:

 

 

  1. //一个固定的无重复的数组,然后把这个数组随机调换位置  
  2. //多次之后这个数组就是一个无重复的随机数组了  
  3. public class Test3  
  4. {  
  5. public static void main(String[] args){  
  6. int n=35;  
  7. int[] nums=new int[n];  
  8. for(int i=0;i<nums.length;i++)  
  9. nums[i]=i+1;  
  10. int temp1,temp2,temp3;  
  11. for(int i=0;i<nums.length;i++){  
  12. temp1=(int)(Math.random()*n);//随机产生一个位置  
  13. temp2=(int)(Math.random()*n);//随机产生另一个位置  
  14. if(temp1!=temp2){  
  15. temp3=nums[temp1];  
  16. nums[temp1]=nums[temp2];  
  17. nums[temp2]=temp3;  
  18. }  
  19. }  
  20. int[] arr=new int[7];  
  21. for(int i=0;i<arr.length;i++){  
  22. arr[i]=nums[i];  
  23. System.out.print(arr[i]+" ");  
  24. }  
  25. }  

 

 

 

方法4:

 

 

  1. //使用HashSet来实现  
  2. import java.util.*;  
  3. public class Test4  
  4. {  
  5. public static void main(String[] arg){  
  6. int n=35;  
  7. Set<Integer> mySet=new HashSet<Integer>();  
  8. while(mySet.size()<7)  
  9. mySet.add((int)(Math.random()*n)+1);  
  10. for(Integer i:mySet)  
  11. System.out.print(i+" ");  
  12. }  

 

 

 

方法5:

 

 

  1. import java.util.*;  
  2. //使用linkedList来实现  
  3. public class Test5  
  4. {  
  5. public static void main(String[] args){  
  6. LinkedList<Integer> mylist=new LinkedList<Integer>();  
  7. int n=35;  
  8. for(int i=0;i<n;i++)  
  9. mylist.add(i+1);  
  10. int[] arr=new int[7];  
  11. for(int i=0;i<arr.length;i++){  
  12. arr[i]=mylist.remove((int)(Math.random()*n));//remove(index i)移除指定位置处得元素  
  13. n--;  
  14. }  
  15. for(int i=0;i<arr.length;i++){  
  16. System.out.print("arr["+i+"]:"+arr[i]+" ");  
  17. }  
  18. }  

 

 

 

希望以上介绍的JAVA的这几种方法,能对你有帮助。

【编辑推荐】

  1. 解析Java代码经常出现的错误
  2. 深入研究Java中“异常机制”
  3. 探讨Java的垃圾回收机制
  4. Java从控制台中读取数据的各种方法
  5. 分享JavaScript的跨域共享的方法
责任编辑:于铁 来源: 互联网
相关推荐

2009-06-17 17:37:43

Java随机数

2012-03-22 09:31:14

Java

2009-06-11 15:16:18

不重复随机数Java

2019-09-11 10:09:00

Java虚拟机算法

2023-01-03 07:49:45

Java随机数线程

2010-10-09 15:35:25

MySQL rand函

2011-06-16 10:48:33

session

2010-02-01 17:02:53

C++产生随机数

2009-07-06 15:11:18

Java 随机数

2009-03-02 17:49:21

LinuxUbuntu轻松截图

2009-06-09 11:19:49

2015-10-13 10:00:58

Swift随机数使用总结

2021-12-27 09:31:20

HashtableJava随机数

2009-03-05 09:35:18

LinuxUbuntu截图

2010-02-04 16:14:56

Ubuntu QQ

2021-06-01 22:31:57

区块链随机数技术

2024-01-25 11:32:21

2014-05-13 10:21:00

2010-03-22 19:41:31

2017-05-29 09:56:25

点赞
收藏

51CTO技术栈公众号