- 浏览: 459800 次
- 性别:
- 来自: 杭州
文章分类
最新评论
-
ty1972873004:
sunwang810812 写道我运行了这个例子,怎么结果是这 ...
Java并发编程: 使用Semaphore限制资源并发访问的线程数 -
lgh1992314:
simpleDean 写道请问,Logger.setLevel ...
Java内置Logger详解 -
sunwang810812:
我运行了这个例子,怎么结果是这样的:2号车泊车6号车泊车5号车 ...
Java并发编程: 使用Semaphore限制资源并发访问的线程数 -
jp260715007:
nanjiwubing123 写道参考你的用法,用如下方式实现 ...
面试题--三个线程循环打印ABC10次的几种解决方法 -
cb_0312:
SurnameDictionary文章我没看完,现在懂了
中文排序
Java中提供了好几个类,可以让我们方便的实现随机数等功能,这些类有java.util.Random, java.util.UUID 以及JDK 7 新引入的java.util.concurrent.ThreadLocalRandom等。
本文将通过这些类对平时使用的实例进行简单的总结,这些实例的功能大致可以分成四个方面:
1. 随机产生N个指定范围内[Min,Max)的随机数
/** * 使用java.util.Random产生一个长度为expectedNum的随机数组,随机数的范围[min,max) */ public int[] gerateRandomArrayWithRange1(int min, int max, int expectedNum) { int[] randomArray = new int[expectedNum]; Random random = new Random(); for (int i = 0; i < expectedNum; i++) { randomArray[i] = random.nextInt(max - min) + min; } return randomArray; } /** * JDK 7 引入java.util.concurrent.ThreadLocalRandom,使用ThreadLocalRandom可以让产生范围内的随机数变得更加方便。 */ public int[] gerateRandomArrayWithRange2(int min, int max, int expectedNum) { int[] randomArray = new int[expectedNum]; for (int i = 0; i < expectedNum; i++) { randomArray[i] = ThreadLocalRandom.current().nextInt(min, max); } return randomArray; }
2. 随机生成和为S的N个正整数
/** * 随机产生和为S的N个随机正整数 * * 思路: * 第一步:把和为S的数值看做是一把尺子的长度,比如S=20。 * 那么随机产生和为S的N个整数的问题就变成了在0~20之间产生N-1不同的刻度。这样的话,尺子就被不同的刻度分割成了N段。 * 第二步:从左到右,计算出每一段的长度,每一段的长度就可以看做是随机数。N段就有了N个随机数。 */ public int[] generateRandomArray(int expectedSum, int expectedNum, boolean ordered) { Set<Integer> set = new TreeSet<Integer>(); /* * 先将最两端的刻度加入到集合中去。 */ set.add(0); set.add(expectedSum); Random random = new Random(); while (set.size() < expectedNum + 1) { set.add(random.nextInt(expectedSum - 1) + 1); } Integer[] locations = new Integer[set.size()]; set.toArray(locations); int[] result = new int[expectedNum]; /* * 计算相邻刻度之间的长度,得到的数值就可以认为是随机数: */ for (int i = 0; i < result.length; i++) { result[i] = locations[i + 1] - locations[i]; } /* * 如果想让得到的随机数从小到大排列,则调用Arrays.sort */ if(ordered) { Arrays.sort(result); } return result; }
随机生成和为S的N个正整数的部分也可以参考如下的博文:
http://mouselearnjava.iteye.com/blog/1858974
3. 随机获取唯一的标识字符串
/** * 直接调用UUID获取随机字符串(包含'-') * * 可用作数据库表的主键 * * 如: 53b25837-05f1-4be2-9c81-2f8bc898f6bd */ public String randomUUID1() { return UUID.randomUUID().toString(); } /** * 直接调用UUID获取随机字符串(不包含'-') * * * 可用作数据库表的主键 * * 如: 97013848ac764487b01d0470cdde3f1a */ public String randomUUID2() { return UUID.randomUUID().toString().replaceAll("-", ""); }
这样随机产生的UUID字符串可用作数据库表的主键。
4. 使用Collections.shuffle随机打乱指定List的顺序
/** * 使用Collections的shuffle方法,将已有的List顺序随机打乱。 */ public void shuffle(List<?> list) { Collections.shuffle(list); }
这样的方法可用于洗牌等方面。
洗牌的博文也可以参考:http://mouselearnjava.iteye.com/blog/1858970
实现上述功能的类的详细内容如下:
package my.random; import java.util.Arrays; import java.util.Collections; import java.util.List; import java.util.Random; import java.util.Set; import java.util.TreeSet; import java.util.UUID; import java.util.concurrent.ThreadLocalRandom; public class RandomUtils { /** * 使用java.util.Random产生一个长度为expectedNum的随机数组,随机数的范围[min,max) */ public int[] gerateRandomArrayWithRange1(int min, int max, int expectedNum) { int[] randomArray = new int[expectedNum]; Random random = new Random(); for (int i = 0; i < expectedNum; i++) { randomArray[i] = random.nextInt(max - min) + min; } return randomArray; } /** * JDK 7 引入java.util.concurrent.ThreadLocalRandom,使用ThreadLocalRandom可以让产生范围内的随机数变得更加方便。 */ public int[] gerateRandomArrayWithRange2(int min, int max, int expectedNum) { int[] randomArray = new int[expectedNum]; for (int i = 0; i < expectedNum; i++) { randomArray[i] = ThreadLocalRandom.current().nextInt(min, max); } return randomArray; } /** * 随机产生和为S的N个随机正整数 * * 思路: * 第一步:把和为S的数值看做是一把尺子的长度,比如S=20。 * 那么随机产生和为S的N个整数的问题就变成了在0~20之间产生N-1不同的刻度。这样的话,尺子就被不同的刻度分割成了N段。 * 第二步:从左到右,计算出每一段的长度,每一段的长度就可以看做是随机数。N段就有了N个随机数。 */ public int[] generateRandomArray(int expectedSum, int expectedNum, boolean ordered) { Set<Integer> set = new TreeSet<Integer>(); /* * 先将最两端的刻度加入到集合中去。 */ set.add(0); set.add(expectedSum); Random random = new Random(); while (set.size() < expectedNum + 1) { set.add(random.nextInt(expectedSum - 1) + 1); } Integer[] locations = new Integer[set.size()]; set.toArray(locations); int[] result = new int[expectedNum]; /* * 计算相邻刻度之间的长度,得到的数值就可以认为是随机数: */ for (int i = 0; i < result.length; i++) { result[i] = locations[i + 1] - locations[i]; } /* * 如果想让得到的随机数从小到大排列,则调用Arrays.sort */ if(ordered) { Arrays.sort(result); } return result; } /** * 使用Collections的shuffle方法,将已有的List顺序随机打乱。 */ public void shuffle(List<?> list) { Collections.shuffle(list); } /** * 直接调用UUID获取随机字符串(包含'-') * * 可用作数据库表的主键 * * 如: 53b25837-05f1-4be2-9c81-2f8bc898f6bd */ public String randomUUID1() { return UUID.randomUUID().toString(); } /** * 直接调用UUID获取随机字符串(不包含'-') * * * 可用作数据库表的主键 * * 如: 97013848ac764487b01d0470cdde3f1a */ public String randomUUID2() { return UUID.randomUUID().toString().replaceAll("-", ""); } }
测试代码如下:
package my.random; import java.util.ArrayList; import java.util.List; public class Main { public static void main(String[] args) { RandomUtils util = new RandomUtils(); System.out.println("随机产生和为30的5个正整数如下:"); printArray(util.generateRandomArray(30, 5, false)); System.out.println(); System.out.println("产生20个[1,100)范围的随机数:"); int[] randomArray1 = util.gerateRandomArrayWithRange1(1, 100, 20); printArray(randomArray1); System.out.println(); System.out.println("产生20个[1,100)范围的随机数:使用JDK 7 的 ThreadRandomLocal"); int[] randomArray2 = util.gerateRandomArrayWithRange1(1, 100, 20); printArray(randomArray2); System.out.println(); System.out.println("使用java.util.UUID产生唯一的标记(包括'-')"); System.out.println(util.randomUUID1()); System.out.println(); System.out.println("使用java.util.UUID产生唯一的标记(不包括'-')"); System.out.println(util.randomUUID2()); System.out.println(); System.out.println("使用Collections.shuffle打乱已有List的顺序:"); List<Integer> intList = new ArrayList<Integer>(); for (int i = 1; i <= 15; i++) { intList.add(i); } System.out.println("调用shuffle方法之前数组的内容是: "); printArray(intList); System.out.println("调用shuffle方法之后数组的内容是: "); util.shuffle(intList); printArray(intList); } /** * 打印整形数组中的数组内容 */ private static void printArray(int[] data) { for (int i : data) { System.out.print(i); System.out.print(" "); } System.out.println(); } private static void printArray(List<? extends Object> list) { for(Object o : list) { System.out.print(o + " "); } System.out.println(); } }
某一次运行结果如下:
随机产生和为30的5个正整数如下:
1 9 5 4 11
产生20个[1,100)范围的随机数:
59 61 4 6 54 25 36 21 29 65 32 37 80 97 98 30 26 29 38 12
产生20个[1,100)范围的随机数:使用JDK 7 的 ThreadRandomLocal
2 32 93 22 79 69 64 6 75 30 9 56 54 32 43 85 67 78 11 11
使用java.util.UUID产生唯一的标记(包括'-')
5113436d-7b79-4c4a-8bc5-a3a66d950de3
使用java.util.UUID产生唯一的标记(不包括'-')
4d505776c16243419f0e6eece940424c
使用Collections.shuffle打乱已有List的顺序:
调用shuffle方法之前数组的内容是:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
调用shuffle方法之后数组的内容是:
12 7 4 2 13 14 9 15 5 10 1 3 6 8 11
发表评论
-
工厂类中移除if/else语句
2016-07-10 19:52 847面向对象语言的一个强大的特性是多态,它可以用来在代码中移除 ... -
Java编程练手100题
2014-12-11 17:13 6667本文给出100道Java编程练手的程序。 列表如下: 面 ... -
数组复制的三种方法
2014-11-30 12:57 2172本文将给出三种实现数组复制的方法 (以复制整数数组为例)。 ... -
数组复制的三种方法
2014-11-30 12:54 0本文将给出三种实现数组复制的方法 (以复制整数数组为例)。 ... -
四种复制文件的方法
2014-11-29 13:21 1681尽管Java提供了一个类ava.io.File用于文件的操 ... -
判断一个字符串中的字符是否都只出现一次
2014-11-25 12:58 2651本篇博文将给大家带来几个判断一个字符串中的字符是否都只出现一 ... -
使用正则表达式判断一个数是否为素数
2014-11-23 13:35 2101正则表达式能够用于判断一个数是否为素数,这个以前完全没有想过 ... -
几个可以用英文单词表达的正则表达式
2014-11-21 13:12 3694本文,我们将来看一下几个可以用英文单词表达的正则表达式。这些 ... -
(广度优先搜索)打印所有可能的括号组合
2014-11-20 11:58 1911问题:给定一个正整n,作为括号的对数,输出所有括号可能 ... -
随机产生由特殊字符,大小写字母以及数字组成的字符串,且每种字符都至少出现一次
2014-11-19 14:48 3936题目:随机产生字符串,字符串中的字符只能由特殊字符 (! ... -
找出1到n缺失的一个数
2014-11-18 12:57 3112题目:Problem description: You h ... -
EnumSet的几个例子
2014-11-14 16:24 8703EnumSet 是一个与枚举类型一起使用的专用 Set 实现 ... -
给定两个有序数组和一个指定的sum值,从两个数组中各找一个数使得这两个数的和与指定的sum值相差最小
2014-11-12 11:24 3281题目:给定两个有序数组和一个指定的sum值,从两个数组 ... -
Java面试编程题练手
2014-11-04 22:49 6649面试编程 写一个程序,去除有序数组中的重复数字 编 ... -
Collections用法整理
2014-10-22 20:55 9795Collections (java.util.Collect ... -
The Code Sample 代码实例 个人博客开通
2014-09-04 18:48 1368个人博客小站开通 http://thecodesample. ... -
Collections.emptyXXX方法
2014-06-08 13:37 2100从JDK 1.5开始, Collections集合工具类中预先 ... -
这代码怎么就打印出"hello world"了呢?
2014-06-08 00:37 7353for (long l = 4946144450195624L ... -
最短时间过桥
2014-04-21 22:03 4068本文用代码实现最短时间过桥,并且打印如下两个例子的最小过桥时间 ... -
将数组分割成差值最小的子集
2014-04-20 22:34 2836本文使用位掩码实现一个功能 ==》将数组分割成差值最小的子集 ...
相关推荐
java学习资料—实例解析常用Java随机数生成;java学习资料—实例解析常用Java随机数生成;java学习资料—实例解析常用Java随机数生成;java学习资料—实例解析常用Java随机数生成
题目是: 有一个一维数组charArray,长度为14个字符,编写程序随即从字符 ‘0’到字符‘9’和字符’a’,’b’,’c’,’d’共有14个字符,编写程序随即从字符数组中获取4个字符,组成一个字符串,要求该字符串可以...
此文档以一个小的实例讲解了java随机数random的使用,在java当中随机数的使用率较高,所以需要熟练掌握随机数的使用
Java随机数算法原理与实现方法实例详解.docx
在Java中,生成随机数可以使用java.util.Random类或java.util.concurrent.ThreadLocalRandom类。这两个类提供了生成伪随机数的方法,下面是它们的详细介绍: 使用java.util.Random类生成随机数: 创建Random类的...
1.java.lang.Math.random() 在所有其他语言中,生成随机数就像是使用Math工具类,如abs, pow, floor, sqrt和其他数学函数。大多数人通过书籍、教程和课程来了解这个类。一个简单的例子:从0.0到1.0之间可以生成一个...
主要介绍了Java随机数算法原理与实现方法,简单分析了随机数算法的原理并结合具体实例形式给出了java编程计算随机数的具体操作技巧,需要的朋友可以参考下
下面小编就为大家带来一篇Java生产1-100的随机数简单实例(分享)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
java swing 随机数抽签程序,基于java swing编写,主要是学习swing的众多操作,一些基本组件的使用,但本抽签程序实际上效果挺不错,项目源码中已编译生成有exe可执行文件,不过运行需要你的电脑中安装有Java 环境 ...
下面小编就为大家带来一篇java随机数生产算法实例。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
要使用这个方法,首先要生成一个实例。来调用它的nextInt(),nextDouble(), nextLong() 等等 我们可以使用这个类来生成随机的 integer, float, double, long, booleans 我们可以传递一个参数到这个方法里,来设置一个...
主要介绍了java生成随机数的常用方法,结合实例形式分析了java生成随机数常用的方法功能与相关使用技巧,需要的朋友可以参考下
本篇文章主要介绍了JAVA 生成随机数并根据后台概率灵活生成的实例代码,具有一定的参考价值,有兴趣的可以了解一下
实例154 使用静态成员变量计算内存中实例化的对象数目 239 实例155 实现加减乘除的方法 240 8.3 面向对象的设计模式 241 实例156 Singleton单例模式 242 实例157 招聘(简单工厂模式) 243 实例158 同学聚会(工厂...
est类用于接收数采仪数据,然后核对其CRC校验是否...然后到DB中查找实时检测值,若未有实时数据可用本实例中的随机数代替,然后保存发送数据到数据库中。得到值后通过CRC16得到其校验码组成其要发送的字节,发送完毕。
实例3 在Eclipse中创建第一个Java程序 4 常见问题 javac不是内部或者外部命令 6 常见问题 找不到类文件 6 常见问题 语法错误 7 第2章 Java基础语法 9 实例4 变量和常量 9 实例5 基本数据类型转换 10 实例6 ...
主要介绍了Java使用Random类生成随机数,结合实例形式分析了java基于Random类生成随机数与遍历输出相关操作技巧,需要的朋友可以参考下
java扔骰子实例Scanner sc=new Scanner(System.in); //标准输入设备 Random rd = new Random(); //随机数对象 int computerSUM=0; int userSUM=0; int sum = 500; //用户总分 int pay = 0; //用户押分 int[]...
//生成0到7之间的随机数 } else { r2 = random.nextInt(16); //生成0到16之间的随机数 } String str_r2 = rBase[r2]; // 生成第1位的位码 int r3 = random.nextInt(6) + 10; //生成10到16之间的随机数 ...
实例154 使用静态成员变量计算内存中实例化的对象数目 239 实例155 实现加减乘除的方法 240 8.3 面向对象的设计模式 241 实例156 Singleton单例模式 242 实例157 招聘(简单工厂模式) 243 实例158...