JAVA随机数之多种方法从给定范围内随机N个不重复数
一、JAVA中生成随机数的方式
1、在j2se中使用Math.random()令系统随机选取一个0~1之间的double类型小数,将其乘以一个数,比如25,就能得到一个0~25范围内的随机数,这个在j2me中没有;
- int randomNumber = (int) Math.round(Math.random()*(max-min)+min);
2、在System类中有一个currentTimeMillis()方法,这个方法返回从1970年1月1号0点0分0秒到目前的一个long型的毫秒 数,可作为一个随机数,还可以将其对某些数取模,就能限制随机数的范围;此方式在循环中同时产生多个随机数时,会是相同的值,有一定的局限性!
- long randomNum = System.currentTimeMillis();
- int randomNumber = (int) randomNum%(max-min)+min;
3、使用java.util.Random类来产生一个随机数发生器,这个也是我们在j2me的程序里经常用的一个取随机数的方法。它有两种形式的构造函 数,分别是Random()和Random(long seed)。Random()使用当前时间即System.currentTimeMillis()作为发生器的种子,Random(long seed)使用指定的seed作为发生器的种子。随机数发生器(Random)对象产生以后,通过调用不同的method:nextInt()、 nextLong()、nextFloat()、nextDouble()等获得不同类型随机数。 如果两个Random对象使用相同的种子(比如都是25),并且以相同的顺序调用相同的函数,那它们返回值完全相同。
- Random random = new Random();
- int randomNumber = random.nextInt(max)%(max-min+1) + min;
二、随机给定范围内N个不重复的数
1、方法一:最简单最易理解的两重循环去重
- /**
- * 随机指定范围内N个不重复的数
- * 最简单最基本的方法
- * @param min 指定范围最小值
- * @param max 指定范围最大值
- * @param n 随机数个数
- */
- public static int[] randomCommon(int min, int max, int n){
- if (n > (max - min + 1) || max < min) {
- return null;
- }
- int[] result = new int[n];
- int count = 0;
- while(count < n) {
- int num = (int) (Math.random() * (max - min)) + min;
- boolean flag = true;
- for (int j = 0; j < n; j++) {
- if(num == result[j]){
- flag = false;
- break;
- }
- }
- if(flag){
- result[count] = num;
- count++;
- }
- }
- return result;
- }
2、方法二:利用HashSet的特征,只能存放不同的值
- /**
- * 随机指定范围内N个不重复的数
- * 利用HashSet的特征,只能存放不同的值
- * @param min 指定范围最小值
- * @param max 指定范围最大值
- * @param n 随机数个数
- * @param HashSet<Integer> set 随机数结果集
- */
- public static void randomSet(int min, int max, int n, HashSet<Integer> set) {
- if (n > (max - min + 1) || max < min) {
- return;
- }
- for (int i = 0; i < n; i++) {
- // 调用Math.random()方法
- int num = (int) (Math.random() * (max - min)) + min;
- set.add(num);// 将不同的数存入HashSet中
- }
- int setSize = set.size();
- // 如果存入的数小于指定生成的个数,则调用递归再生成剩余个数的随机数,如此循环,直到达到指定大小
- if (setSize < n) {
- randomSet(min, max, n - setSize, set);// 递归
- }
- }
3、方法三:排除已随机到的数
- /**
- * 随机指定范围内N个不重复的数
- * 在初始化的无重复待选数组中随机产生一个数放入结果中,
- * 将待选数组被随机到的数,用待选数组(len-1)下标对应的数替换
- * 然后从len-2里随机产生下一个随机数,如此类推
- * @param max 指定范围最大值
- * @param min 指定范围最小值
- * @param n 随机数个数
- * @return int[] 随机数结果集
- */
- public static int[] randomArray(int min,int max,int n){
- int len = max-min+1;
- if(max < min || n > len){
- return null;
- }
- //初始化给定范围的待选数组
- int[] source = new int[len];
- for (int i = min; i < min+len; i++){
- source[i-min] = i;
- }
- int[] result = new int[n];
- Random rd = new Random();
- int index = 0;
- for (int i = 0; i < result.length; i++) {
- //待选数组0到(len-2)随机一个下标
- index = Math.abs(rd.nextInt() % len--);
- //将随机到的数放入结果集
- result[i] = source[index];
- //将待选数组中被随机到的数,用待选数组(len-1)下标对应的数替换
- source[index] = source[len];
- }
- return result;
- }
调用实例:
- public static void main(String[] args) {
- int[] reult1 = randomCommon(20,50,10);
- for (int i : reult1) {
- System.out.println(i);
- }
- int[] reult2 = randomArray(20,50,10);
- for (int i : reult2) {
- System.out.println(i);
- }
- HashSet<Integer> set = new HashSet<Integer>();
- randomSet(20,50,10,set);
- for (int j : set) {
- System.out.println(j);
- }
- }
JAVA随机数之多种方法从给定范围内随机N个不重复数的更多相关文章
- java 键盘输入多种方法 .(转载)
一.java不像C中拥有scanf这样功能强大的函数,大多是通过定义输入输出流对象.常用的类有BufferedReader,Scanner. 实例程序: 1.利用 Scanner 实现从键盘读入int ...
- java 键盘输入多种方法
转! 分类: java学习2012-11-04 09:58 8427人阅读 评论(1) 收藏 举报 一.java不像C中拥有scanf这样功能强大的函数,大多是通过定义输入输出流对象.常用的类有Buf ...
- java读取文件多种方法
1.按字节读取文件内容2.按字符读取文件内容3.按行读取文件内容 4.随机读取文件内容 public class ReadFromFile { /** * 以字节为单位读取文件,常用 ...
- Java中int和String互相转换的多种方法
1 如何将字串 String 转换成整数 int? A. 有两个方法: 1). int i = Integer.parseInt([String]); 或 i = Integer.parseInt([ ...
- JAVA生成随机数种子的方法
Java里面有一个随机函数——Random,刚开始只是知道这个函数具有随机取值的作用,于是上网搜索了资料一番,做了一下一些关于Random函数的总结: Java中存在着两种Random函数: 一. ...
- 使用mshta.exe绕过应用程序白名单(多种方法)
0x00 简介 很长一段时间以来,HTA文件一直被web攻击或在野恶意软件下载程序用作恶意程序的一部分.HTA文件在网络安全领域内广为人知,从红队和蓝队的角度来看,它是绕过应用程序白名单有价值的“ ...
- 硬核 - Java 随机数相关 API 的演进与思考(上)
本系列将 Java 17 之前的随机数 API 以及 Java 17 之后的统一 API 都做了比较详细的说明,并且将随机数的特性以及实现思路也做了一些简单的分析,帮助大家明白为何会有这么多的随机数算 ...
- Java 随机数
本章先讲解Java随机数的几种产生方式,然后通过示例对其进行演示. 广义上讲,Java中的随机数的有三种产生方式:(01). 通过System.currentTimeMillis()来获取一个当前时间 ...
- 学习记录 java随机数的产生机制
java 随机数 一.在j2se里我们可以使用Math.random()方法来产生一个随机数,这个产生的随机数是0-1之间的一个double,我们可以把他乘以一定的数,比如说乘以100,他就是个100 ...
随机推荐
- FFmpeg开发环境构建
本文为作者原创,转载请注明出处:https://www.cnblogs.com/leisure_chn/p/10035365.html 1. 相关资源介绍 本文主要讲述 linux 平台 x86(及x ...
- UML类图示例
- 我的Visual Studio必用工具
自己备用 代码生成工具:Resharper 代码颜色:supercharger 高亮单词 Word highlight with margin Productivity Power Tools 详细介 ...
- docker下安装vim
进入docker内部后,发现之前的vim命令用不了了,这个时候就需要重新安装vim,具体步骤如下: 更新源 apt-get update 安装vim apt-get install vim
- Java 支付宝支付,退款,单笔转账到支付宝账户(支付宝订单退款)
上一篇写到支付宝的支付,这代码copy下来就能直接用了, 我写学习文档时会经常贴 官方参数文档的案例地址, 因为我觉得 请求参数,响应参数说明 官方文档整理的很好,毕竟官方不会误导大家. 我学一个 ...
- 最短路(hdu2544)Dijkstra算法二
最短路 Time Limit: 5000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submis ...
- EF CodeFirst(三) 并发处理
并发分为两种,一种叫做悲观并发,一种叫乐观并发. 名字挺文艺 悲观并发 悲观并发是什么呢? 就拿我们常用的代码版本控制来说. 有一个文档,A和B都要 获取这个文档并进行修改, 如果当A在读取这个文档数 ...
- JVM复习--新生代GC
在复习Java内存机制的过程中有一些新问题,自问自答,做个记录.新生代是java堆内存的一部分.堆内存分新生代和老生代两大块,也有把堆内存分为新生代老生代永久代(持久代)三块的说法.(不过这种说法应该 ...
- Linux常用基本命令(xargs )
xargs:能够将管道或者标准输入传递的数据转换成xargs命令后面跟随的参数 ghostwu@dev:~/linux/cp$ ls ghostwu_hardlink ghostwu_home gho ...
- Sql Server分页储存过程
--分页储存过程if exists (select * from sys.procedures where name='Page')drop proc Pagegocreate proc Page@P ...