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 ...
随机推荐
- T4模板根据数据库表和列的Description生成代码的summary的终极解决方案
相信很多人都用T4模版生成代码,用T4模版生成标准代码真的很方便.我们经常根据表生成相关的代码, 但是估计很多人都遇见过同一个问题, 特别是我们在生成model的时候,代码中model中的Summar ...
- django2.1---终端打印orm转义的sql语句
print(connection.queries)可以打印转义后的sql语句 例子: from django.http import JsonResponse,HttpResponse from .m ...
- 处理html内容,获取纯文本
import com.alibaba.fastjson.JSONArray; import com.alibaba.fastjson.JSONObject; import java.util.rege ...
- .net 多线程的使用(Thread)
上篇 net 同步异步 中篇 多线程的使用(Thread) 下篇 net 任务工厂实现异步多线程 Thread多线程概述 上一篇我们介绍了net 的同步与异步,我们异步演示的时候使用的是委托多线程来实 ...
- [日常] Go语言圣经-指针对象的方法-bit数组习题
练习6.1: 为bit数组实现下面这些方法 func (*IntSet) Len() int // return the number of elements func (*IntSet) Remov ...
- [日常] Go语言圣经-Panic异常,Recover捕获异常习题
Go语言圣经-Panic异常1.当panic异常发生时,程序会中断运行,并立即执行在该goroutine中被延迟的函数(defer 机制)2.不是所有的panic异常都来自运行时,直接调用内置的pan ...
- 使用 RabbitMQ 实现异步调用
目录 引言 启动 RabbitMQ 服务器 运行 rabbitmq 容器 RabbitMQ 控制台 Exchange 和 Queue 开发服务端和客户端 开发服务端 开发客户端 Java Bean 类 ...
- 山东省第四届acm解题报告(部分)
Rescue The PrincessCrawling in process... Crawling failed Description Several days ago, a beast ca ...
- 1-初识java
目录 java 历史 Java 平台 Java 开发环境 Java 运行原理[简] Java 历史 这里不详细记录java的历史,只是标记出时间点和事件. 时间点 事件 1991 Sun公司成立Gre ...
- Jquery 清除空白字符
$.grep(“jQuery数组”, function(n) { return $.trim(n).length > 0; }); /*仅过滤空数组,不过滤相同数组*/