【Java编程】随机数的不重复选择
随机数的不重复选择就是从n个数中随机选取m(m<n)个数。在本文中,我们用Java来实现。因此我们先介绍Java的相关知识。
在Java中,Java.util.Set接口和Java.util.List接口一样,都是继承自Java.util.Collection接口。但是两者有不同的特点:
package tengwei.com; import java.util.*; public class UseVector { public static void main(String[] args) { // TODO Auto-generated method stub Vector<Integer> vec=selectSeven();//调用函数 Enumeration<Integer> enu=vec.elements();//得到向量中所有元素的枚举 while(enu.hasMoreElements())//遍历向量中的所有元素 System.out.println(enu.nextElement()+"\t"); Object obj[]=vec.toArray();//把向量vec转化为Oject数组 Arrays.sort(obj);//升序排序 System.out.println("升序排列后:"); for(int i=0;i<obj.length;i++) System.out.println(obj[i]+"\t"); } /**从1-36中随机选择7个不重复的数 */ public static Vector<Integer> selectSeven() { Random rd= new Random();//创建随机数对象 Vector<Integer> allNum = new Vector<Integer>();//存放1-36 Vector<Integer> sevenNum = new Vector<Integer>();//存放选择的7个数 for(int i=0;i<36;i++) allNum.add(new Integer(i+1));//向向量allNum中添加36个数 int x; for(int i=0;i<7;i++) { x=rd.nextInt(36-i);//得到0-(36-i)中随机数,不包含36-i sevenNum.add(allNum.get(x)); allNum.remove(x); } return sevenNum; } }
本算法的基本思想就是先用Vector保存你的样本空间(36个数),然后产生一个随机数,以随机数为下标来取出样本空间的数,并且将该数从样本空间删除。该算法的缺点是原始样本空间不能有重复的数,当样本空间很大的时候,会占用很多内存空间。当然还有几种算法也可以选择,具体请查看下一篇文章。
package tengwei.com; import java.util.*; public class UseHashSetTreeSet { public static void main(String[] args) { // TODO Auto-generated method stub Set<Integer> hashset = hashSelect(7);//调用函数,返回哈希集 System.out.println("HashSet中所有元素(未排列)"); System.out.println("\t"+hashset); SortedSet<Integer> treeset = treeSelect(7);//调用函数,返回数集 System.out.println("TreeSet中所有元素(升序)"); System.out.println("\t"+treeset); } public static Set<Integer> hashSelect(int k) { Random rd = new Random(); Set<Integer> hs= new HashSet<Integer>(); while(hs.size()<k) { int x=1+rd.nextInt(36);//随机1-36之间的数,包括两边 hs.add(new Integer(x)); } return hs; } public static SortedSet<Integer> treeSelect(int k) { Random rd = new Random(); SortedSet<Integer> ts= new TreeSet<Integer>(); while(ts.size()<k) { int x=1+rd.nextInt(36); ts.add(new Integer(x));//当重复时不会添加 } return ts; } }
上面的算法比较简单,比较巧妙的用到了Set接口的特性。
原文:http://blog.csdn.net/tengweitw/article/details/24395949
作者:nineheadedbird
【Java编程】随机数的不重复选择的更多相关文章
- java,url长链接生成短链接,短链接生成器,自定义字符串,对字符串md5混合KEY加密,根据短链接获得key值,不重复的随机数,不重复的随机字符串
java,url长链接生成短链接,短链接生成器,自定义字符串,对字符串md5混合KEY加密,根据短链接获得key值,不重复的随机数,不重复的随机字符串 package com.zdz.test; im ...
- Java编程基础-选择和循环语句
一.选择结构语句 选择结构:也被称为分支结构.选择结构有特定的语法规则,代码要执行具体的逻辑运算进行判断,逻辑运算的结果有两个,所以产生选择,按照不同的选择执行不同的代码. Java语言提供了两种选择 ...
- java 获取随机数的三种方法
方法1(数据类型)(最小值+Math.random()*(最大值-最小值+1))例:(int)(1+Math.random()*(10-1+1))从1到10的int型随数 方法2获得随机数for (i ...
- Java获取随机数的几种方法
Java获取随机数的几种方法 .使用org.apache.commons.lang.RandomStringUtils.randomAlphanumeric()取数字字母随机10位; //取得一个3位 ...
- Java编程的逻辑 (34) - 随机
本系列文章经补充和完善,已修订整理成书<Java编程的逻辑>,由机械工业出版社华章分社出版,于2018年1月上市热销,读者好评如潮!各大网店和书店有售,欢迎购买,京东自营链接:http:/ ...
- Java编程的逻辑 (40) - 剖析HashMap
本系列文章经补充和完善,已修订整理成书<Java编程的逻辑>,由机械工业出版社华章分社出版,于2018年1月上市热销,读者好评如潮!各大网店和书店有售,欢迎购买,京东自营链接:http:/ ...
- JAVA编程思想——分析阅读
需要源码.JDK1.6 .编码风格参考阿里java规约 7/12开始 有点意识到自己喜欢理论大而泛的模糊知识的学习,而不喜欢实践和细节的打磨,是因为粗心浮躁导致的么? cron表达式使用 设计能力.领 ...
- Java编程中“为了性能”尽量要做到的一些地方
最近的机器内存又爆满了,除了新增机器内存外,还应该好好review一下我们的代码,有很多代码编写过于随意化,这些不好的习惯或对程序语言的不了解是应该好好打压打压了. 下面是参考网络资源总结的一些在Ja ...
- JAVA编程“性能说”(java编程需要做的26件事)
转载于 http://www.csdn.net/article/2012-06-01/2806249 最近的机器内存又爆满了,除了新增机器内存外,还应该好好review一下我们的代码,有很多代码编写过 ...
随机推荐
- Ajax+Struts2实现验证码验证功能
---------------------------------------------------------------------------------------------------- ...
- 微信小程序基础之交互操作控件
好久没有写关于微信小程序的文章了,今天简单的发表一篇,内容比较简单,包括:ActionSheet上拉菜单.AlertAction提示框.SuccessAction完成框.LoadingAction加载 ...
- 阻塞IO服务器模型之多线程服务器模型
针对单线程服务器模型的特点,我们可以对其进行改进,使之能对多个客户端同时进行响应.最简单的改进即是使用多线程(或多进程)服务器模型,在应用层级别,我们一般采用多线程模式.多线程能让多个客户端同时请求, ...
- linux下的清屏命令
Linux下有两个清屏命令: clear 这个命令将会刷新屏幕,系统的操作是让终端显示页向后翻了一页,如果向上滚动屏幕还可以看到之前的操作信息.一般都会使用这个命令. reset 这个命令将完全刷新终 ...
- 02_3中方式的反射,通过Class.forName获得Class对象,通过类.class获得字节码对象,通过类实例.getClass()的方式获得Class对象
反射中加载类: Java中有一个Class类用于代表某一个类的字节码 .class文件 对应Class //1 加载类 // java中Class代表一个类,但是到底代表哪个类要明确指出 ...
- [ExtJS5学习笔记]第六节 Extjs的类系统Class System命名规则及定义和调试
本文地址: http://blog.csdn.net/sushengmiyan/article/details/38479079 本文作者:sushengmiyan ----------------- ...
- EBS总账模块与其他模块数据关联关系
表名:GL_IMPORT_REFERENCES 说明:总账导入附加信息表 用途:用来追溯从子模块传入总账模块的明细,对于报表开发很有帮助 SQL 语句: select * from gl_je_hea ...
- UITableView如何撤销移动操作
大熊猫猪·侯佩原创或翻译作品.欢迎转载,转载请注明出处. 如果觉得写的不好请多提意见,如果觉得不错请多多支持点赞.谢谢! hopy ;) 我们知道使用UITableView的委托方法canMoveRo ...
- Struts2配置问题终极解决方案
从下午忙到现在,终于找到问题的根源了.写下此文,与君共勉. 我的目录结构是这样的. 关于配置文件加载问题 控制台下面报错,提示错误信息如下: 严重: Exception starting filter ...
- I/O操作之概述与导读
I/O流可以表示很多不同种类的输入源和输出目的地,包括简单的字节流,基本数据(int.boolean.double等),本地化的字符,以及对象.一些流只是简单地传递数据,还有一些流可以操作和转换数据 ...