集合之列表:生成不重复的随机数

  1 package com.jdk7.chapter4;
  2
  3 import java.util.ArrayList;
  4 import java.util.List;
  5 import java.util.Random;
  6
  7 /**
  8  * 指定范围类生成一组指定个数的随机数
  9  *
 10  * @author Administrator
 11  *
 12  */
 13 public class UnRepeatRandomNumber {
 14     private int min;
 15     private int max;
 16
 17     public UnRepeatRandomNumber(){
 18         this.min = 0;
 19         this.max = 10;
 20     }
 21
 22     public UnRepeatRandomNumber(int min, int max){
 23         if(max>=min){
 24             this.min = min;
 25             this.max = max;
 26         }
 27     }
 28
 29     /**
 30      * 返回一组随机数,以Integer[]类型返回,如果数组中已存在生成的随机数,则丢弃,重新生成随机数
 31      * @param length
 32      * @return
 33      */
 34     public Integer[] getMethodA(int length){
 35         if(length<=0){
 36             System.out.println("生成随机数的个数不能小于1");
 37             return  new Integer[0];
 38         }else if(length>(max-min+1)){
 39             System.out.println("生成随机数的个数不能超出取值范围总个数!");
 40             length = (max-min+1);
 41         }
 42         Random random = new Random();
 43         List list = new ArrayList();
 44         //因为不知道具体要循环多少次,所以只能用while的判断条件来进行循环
 45         while((list.size())<length){
 46             int number = min+random.nextInt(max-min+1);
 47             if(!list.contains(number)){
 48                 list.add(number);
 49             }
 50         }
 51         return (Integer[])list.toArray(new Integer[2]);
 52     }
 53
 54     /**
 55      * 按照生成随机数的范围,将所有可能生成的随机数存放在源数组
 56      * 循环体中进行如下操作:
 57      *         随机生成源数组的下标number
 58      *         获取源数组下标number对应的值依次存放入目标数组中
 59      *         源数组中移除存入目标数组的随机数
 60      * 直到目标数组长度达到预期值
 61      * @param length
 62      * @return
 63      */
 64     public Integer[] getMethodB(int length){
 65         if(length<=0){
 66             System.out.println("随机数数组长度不能小于零!");
 67             return new Integer[0];
 68         }else if(length>(this.max-this.min+1)){
 69             System.out.println("生成随机数的个数不能超出取值范围总个数!");
 70             length = this.max-this.min+1;
 71         }
 72         //将所有可能生成的随机数存放在src中
 73         List src = new ArrayList();
 74         for(int i=min;i<(max+1);i++){
 75             src.add(i);
 76             }
 77         Random random = new Random();
 78         //存放需要的目标随机数组
 79         List result = new ArrayList();
 80         //因为这里是先比较大小,再进行添加,循环次数是从0到length-1,达到了数组要求的长度
 81         //如果是先添加数组元素再比较,那么如果希望循环length次的话,判断条件需改为(result.size())<=length
 82         while((result.size())<length){
 83             int number = random.nextInt(src.size());
 84             //从待生成数组中获取对应下标的元素,依次存入目标数组中
 85             result.add(src.get(number));
 86             src.remove(number);
 87         }
 88         return (Integer[])result.toArray(new Integer[0]);
 89     }
 90
 91     public void printInteger(Integer[] integer){
 92         if(integer==null){
 93             System.out.println("数组为空!");
 94         }else if(integer.length<=0){
 95             System.out.println("数组长度小于零!");
 96         }
 97         for(int i=0;i<integer.length;i++){
 98             System.out.print(integer[i]+" ");
 99         }
100         System.out.println();
101     }
102
103 }
 1 package com.jdk7.chapter4;
 2
 3 public class UnRepeatRandomNumberTest {
 4     public static void main(String[] args) {
 5 //        UnRepeatRandomNumber ranumber = new UnRepeatRandomNumber();
 6         UnRepeatRandomNumber ranumber = new UnRepeatRandomNumber(2,12);
 7
 8         ranumber.printInteger(ranumber.getMethodA(12));
 9         ranumber.printInteger(ranumber.getMethodA(0));
10         ranumber.printInteger(ranumber.getMethodA(11));
11
12         ranumber.printInteger(ranumber.getMethodB(12));
13         ranumber.printInteger(ranumber.getMethodB(-1));
14         ranumber.printInteger(ranumber.getMethodB(11));
15     }
16 }
17
18 执行结果:
19 生成随机数的个数不能超出取值范围总个数!
20 8 12 10 3 5 4 11 6 9 2 7
21 生成随机数的个数不能小于1
22 数组长度小于零!
23
24 10 12 7 3 6 4 5 11 2 8 9
25 生成随机数的个数不能超出取值范围总个数!
26 5 3 12 10 6 8 7 9 2 4 11
27 随机数数组长度不能小于零!
28 数组长度小于零!
29
30 11 2 9 7 3 8 12 10 6 4 5 

原文地址:https://www.cnblogs.com/celine/p/8455921.html

时间: 2025-01-07 01:59:59

集合之列表:生成不重复的随机数的相关文章

用C#生成不重复的随机数

对于随机数,大家都知道,计算机不可能产生完全随机的数字,所谓的随机数发生器都是通过一定的算法对事先选定的随机种子做复杂的运算,用产生的结果来近似的模拟完全随机数,这种随机数被称 作伪随机数.伪随机数是以相同的概率从一组有限的数字中选取的.所选数字并不具有完全的随机性,但是从实用的角度而言,其随机程度已足够了.伪随机数的选 择是从随机种子开始的,所以为了保证每次得到的伪随机数都足够地"随机",随机种子的选择就显得非常重要.如果随机种子一样,那么同一个随机数发生器产生 的随机数也会一样.一

[转载][记录]javascript生成不重复的随机数

参考链接:javascript生成不重复的随机数 项目播放视频,是无序的,有上下两个按钮,所以需要生成1,8不重复的随机数数组,如: 7,4,8,6,1,5,3,2 然后再split一次,就是数组了. 拿来主义了

.net中如何生成不重复的随机数

.net中生成不重复的随机数的方法         //获取count个不大于maxNumber的整数,所有整数不重复.当然,count必须小于等于maxNumber         static List<int> GetRandomArray(int maxNumber,int count)         {             List<int> list = new List<int>();//保存取出的随机数             int[] arra

C#生成不重复的随机数(转)

我们在做能自动生成试卷的考试系统时,常常需要随机生成一组不重复随机数的题目,在.net Framework中提供了一个专门用来产生随机数的类System.Random. 对于随机数,大家都知道,计算机不可能产生完全随机的数字,所谓的随机数发生器都是通过一定的算法对事先选定的随机种子做复杂的运算,用产生的结果来近似的模拟完全随机数,这种随机数被称作伪随机数.伪随机数是以相同的概率从一组有限的数字中选取的.所选数字并不具有完全的随机性,但是从实用的角度而言,其随机程度已足够了.伪随机数的选 择是从随

用MySQL里的Rand()生成 不连续重复 的随机数年龄以及随机姓名字符串

前言:        RAND函数,返回在范围0到1.0内的随机浮点值.如果一个整数参数N被指定,它被用作种子值. 一,朋友问题描述如下:(1),有一个用户表,有id,用户的真实名字,年龄.通过一段存储过程来实现向表里插入100数据,其中年龄随机姓名 姓氏:'赵钱孙李周吴郑王';,随机取出一个名字:'一段文字字符串',随机的取出一个字或者两个字要求:随机的名字不能出现连续重复. (2),然后我写出的代码如下:-- 创建用户表,在project里create table user1 (id int

生成不重复的随机数

0x00.从一个数组(arr)随机生成有(num)个不相同的值的数组 function createRandom( num, arr ) { var arrCache = [], objCache = {}; while( arrCache.length < num ) { var randomNum = Math.floor( Math.random() * arr.length ); //通过判断objCache对象的索引值是否存在 来标记 是否重复 if( !objCache[random

C# 使用Guid类生成不重复的随机数

什么是Guid GUID(全局唯一标识符) 全局唯一标识符(GUID,Globally Unique Identifier)是一种由算法生成的二进制长度为128位的数字标识符.GUID主要用于在拥有多个节点.多台计算机的网络或系统中.在理想情况下,任何计算机和计算机集群都不会生成两个相同的GUID.GUID 的总数达到了2^128(3.4×10^38)个,所以随机生成两个相同GUID的可能性非常小,但并不为0.GUID一词有时也专指微软对UUID标准的实现. 在理想情况下,任何计算机和计算机集群

生成不重复的随机数(待完善)

1 // 方法一,用for循环,break跳出语句(不推荐,方法太笨,思路也不是很明确) 2 3 public static void main(String[] args) { 4 5 // 方法二 利用foreach和continue循环并跳出循环 6 7 int[] c = new int[7];// 创建7个数的数列,这个地方可以不用定义数组 8 9 Random ran1 = new Random(); // 实例化对象 10 11 boolean bo = false; // 定义标

JS生成不重复的随机数

// 定义存放生成随机数的数组 var array=new Array(); // 循环N次生成随机数 for(var i = 0 ; ; i++){     // 只生成10个随机数     if(array.length<10){           generateRandom(10);     }else{       break;    } } // 循环遍历随机数数组 for(var i = 0 ; i < array.length; i++){      alert(array[