一、 JAVA中生成随机数的方式
1 、在j2se中使用Math.random()令系统随机选取一个0~1之间的double类型小数将其乘以一个数 比如25就能得到一个0~25范围内的随机数这个在j2me中没有J a va代码
1. int randomNumber = (int) Math.round(Math.random()*(max-min)+min) ;
2、在System类中有一个currentTimeMi l l is()方法这个方法返回从1970年1月1号0点0分0秒到目前的一个long型的毫秒数可作为一个随机数还可以将其对某些数取模就能限制随机数的范围此方式在循环中同时产生多个随机数时会是相同的值有一定的局限性
J a va代码
1. long randomNum = System.currentTimeMillis( );
2. int randomNumber = (int) randomNum%(max-min)+min;
3、使用java.uti l .Random类来产生一个随机数发生器这个也是我们在j2me的程序里经常用的一个取随机数的方法。它有两种形式的构造函数分别是Random()和
Random(long seed)。 Random()使用当前时间即System.currentTimeMi l l is()作为发生器的种子 Random(long seed)使用指定的seed作为发生器的种子。随机数发生器(Random)对象产生以后通过调用不同的method nextInt()、 nextLong()、 nextFloat()、 nextDouble()等获得不同类型随机数。如果两个Random对象使用相同的种子比如都是25 并且以相同的顺序调用相同的函数那它们返回值完全相同。
J a va代码
1. Random random = new Random( );
2. int randomNumber = random.nextInt(max)%(max-min+1) + min;
二、随机给定范围内N个不重复的数
1 、方法一最简单最易理解的两重循环去重
J a va代码
1. /**
2. *随机指定范围内N个不重复的数
3. *最简单最基本的方法
4. * @param min指定范围最小值
5. * @param max指定范围最大值
6. * @param n随机数个数
7. */
8. public static int[] randomCommon(int min, int max, int n){
9. if (n > (max - min + 1) | | max < min) {
10. return null;
11. }
12. int[] result = new int[n] ;
13. int count = 0;
14. while(count < n) {
15. int num = (int) (Math.random( ) * (max - min) ) + min;
16. boolean flag = true;
17. for (int j = 0; j < n; j++) {
18. if(num == result[j]){
19. flag = false;
20. brea k;
21. }
22. }
23. if(flag){
24. result[count] = num;
25. count++;
26. }
27. }
28. return result;
29. }
2、方法二利用HashSet的特征只能存放不同的值
J a va代码
1. /**
2. *随机指定范围内N个不重复的数
3. *利用HashSet的特征只能存放不同的值
4. * @param min指定范围最小值
5. * @param max指定范围最大值
6. * @param n随机数个数
7. * @param HashSet<Integer> set随机数结果集
8. */
9. public static void randomSet(int min, int max, int n, HashSet<Integer> set) {
10. if (n > (max - min + 1) | | max < min) {
11. ret u rn;
12. }
13. for (int i = 0; i < n; i++) {
14. //调用Math.random()方法
15. int num = (int) (Math.random( ) * (max - min) ) + min;
16. set.add(num);//将不同的数存入HashSet中
17. }
18. int setSize = set.size( );
19. //如果存入的数小于指定生成的个数则调用递归再生成剩余个数的随机数如此循环直到达到指定大小
20. if (setSize < n) {
21. randomSet(min, max, n - setSize, set) ;//递归
22. }
23. }
3、方法三排除已随机到的数
J a va代码
1. /**
2. *随机指定范围内N个不重复的数
3. *在初始化的无重复待选数组中随机产生一个数放入结果中
4. *将待选数组被随机到的数用待选数组(len-1)下标对应的数替换
5. *然后从len-2里随机产生下一个随机数如此类推
6. * @param max 指定范围最大值
7. * @param min 指定范围最小值
8. * @param n 随机数个数
9. * @return int[ ]随机数结果集
10. */
11. public static int[] randomArray(int min,int max,int n){
12. int len = max-min+1;
13.
14. if(max < min | | n > len){
15. return null;
16. }
17.
18. //初始化给定范围的待选数组
19. int[] source = new int[len];
20. for (int i = min; i < min+len; i++){
21. source[i-min] = i;
22. }
23.
24. int[] result = new int[n] ;
25. Random rd = new Random( );
26. int index = 0;
27. for (int i = 0; i < result.length; i++) {
28. //待选数组0到(len-2)随机一个下标
29. index = Math.abs(rd.nextInt( ) % len--) ;
30. //将随机到的数放入结果集
31. result[i] = source[index];
32. //将待选数组中被随机到的数用待选数组(len-1)下标对应的数替换
33. source[index] = source[len];
34. }
35. return result;
36. }
调用实例
J a va代码
1. public static void main(String[ ] args) {
2. int[] reult1 = randomCommon(20,50,10);
3. for (int i : reult1) {
4. System.out.println(i) ;
5. }
6.
7. int[] reult2 = randomArray(20,50,10) ;
8. for (int i : reult2) {
9. System.out.println(i) ;
10. }
11.
12. HashSet<Integer> set = new HashSet<Integer>() ;
13. randomSet(20,50,10,set) ;
14. for (int j : set) {
15. System.out.println(j) ;
16. }
17. }
CloudCone的[2021 Flash Sale]活动仍在继续,针对独立服务器、VPS或者Hosted email,其中VPS主机基于KVM架构,最低每月1.99美元,支持7天退款到账户,可使用PayPal或者支付宝付款,先充值后下单的方式。这是一家成立于2017年的国外VPS主机商,提供独立服务器租用和VPS主机,其中VPS基于KVM架构,多个不同系列,也经常提供一些促销套餐,数据中心在洛杉...
RAKsmart 商家我们应该较多的熟悉的,主营独立服务器和站群服务器业务。从去年开始有陆续的新增多个机房,包含韩国、日本、中国香港等。虽然他们家也有VPS主机,但是好像不是特别的重视,价格上特价的时候也是比较便宜的1.99美元月付(年中活动有促销)。不过他们的重点还是独立服务器,毕竟在这个产业中利润率较大。正如上面的Megalayer商家的美国服务器活动,这个同学有需要独立服务器,这里我一并整理...
puaex怎么样?puaex是一家去年成立的国人商家,本站也分享过几次,他家主要销售香港商宽的套餐,给的全部为G口带宽,而且是不限流量的,目前有WTT和HKBN两种线路的方面,虽然商家的价格比较贵,但是每次补一些货,就会被抢空,之前一直都是断货的状态,目前商家进行了补货,有需要这种类型机器的朋友可以入手。点击进入:puaex商家官方网站Puaex香港vds套餐:全部为KVM虚拟架构,G口的带宽,可...