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 ...
随机推荐
- XSS事件(一)
前言 最近做的一个项目因为安全审计需要,需要做安全改造.其中自然就包括XSS和CSRF漏洞安全整改.关于这两个网络安全漏洞的详细说明,可以参照我本篇博客最后的参考链接.当然,我这里并不是想写一篇安 ...
- 使用Akka构建集群(二)
前言 在<使用Akka构建集群(一)>一文中通过简单集群监听器的例子演示了如何使用Akka搭建一个简单的集群,但是这个例子“也许”离我们的实际业务场景太远,你基本不太可能去做这样的工作,除 ...
- 如何判断JavaScript数据具体类型
昨晚做了阿里的题目,让我写一个函数,可以判断数据的具体类型.其实题目很简单的...但是真的是自己不太注意吧,写的很糟糕啊. 然后今天就自己写了一个,然后又到晚上搜了下,看看别人的写法,结果发现自己有点 ...
- ApiGen安装
# 首先,下载ApiGen(http://apigen.org/apigen.phar) # *nix系统 下载phar文件后, 移动到PATH目录中,以保证全局有权限调用 $ mv apigen.p ...
- 并发编程之 wait notify 方法剖析
前言 2018 元旦快乐. 摘要: notify wait 如何使用? 为什么必须在同步块中? 使用 notify wait 实现一个简单的生产者消费者模型 底层实现原理 1. notify wait ...
- 使用ScheduledExecutorService实现任务延迟
在做项目的过程中,遇到一个场景:在审批流中,如果上级领导不审批,则在10分钟后自动审批.也就是要做一个任务在多长时间后执行的效果 在不断的摸索中,想到了使用线程池,发现有个ScheduledExecu ...
- MFC函数—CWinApp::LoadStdProfileSettings
从 InitInstance 成员函数内调用该函数,启用和加载最近使用的(MRU)文件和最后浏览状态的列表.void LoadStdProfileSettings( UINT nMaxMRU = ...
- js 前端分页空间控件
现在web注重用户体验与交互性,ajax 提交数据的方式很早就流行了,它能够在不刷新网页的情况下局部刷新数据.前端分页多是用ajax请求数据(其他方式也有比如手动构造表单模拟提交事件等).通过js将查 ...
- 【Linux】rpm常用命令及rpm参数介绍
RPM是RedhatPackageManager的缩写,是由RedHat公司开发的软件包安装和管理程序,同Windows平台上的Uninstaller比较类似.使用RPM,用户可以自行安装和管理Lin ...
- Jquery/js引入的button的onclik事件只触发一次
目标描述 我要实现的是:通过监听button的click事件,从而通过ajax向servlet发送请求获取数据库中的数据,然后返回的页面,并要求局部刷新 一次页面的加载是html直接页面初始化本身的 ...