首页 > 开发 > Java > 正文

Java编程实现生成给定范围内不重复随机数的方法小结

2024-07-13 10:09:41
字体:
来源:转载
供稿:网友

本文实例总结了Java编程实现生成给定范围内不重复随机数的方法。分享给大家供大家参考,具体如下:

在Java中的Math类中存在一个random()方法,该方法默认生成0.0到1.0之间的double型随机数;经过稍微处理,就可以产生我们需要的随机数以及随机字符。

除了Math类中的random()方法之外,java.util.Random类也可以用来生成随机数;下面分别举例(用不同的方法生成双色球号码)说明:

1. Math.random()方法

生成随机数:

package test;import java.util.SortedSet;import java.util.TreeSet;public class MathRandom {  static SortedSet set = new TreeSet();  public static int randomSet(double m, double n) {    int num = (int) m + (int) (Math.random() * (n - m));    return num;  }  public static void shuangSe(int num1, int num2) {    for (int i = 0; i < num1; i++) {      set.add(randomSet(1, 33));    }    if (set.size() < num2) {      shuangSe(num2 - set.size(), num2);    }  }  public static void main(String[] args) {    shuangSe(6, 6);    System.out.print(set);    System.out.println("  "+randomSet(1,16));  }}

运行结果(随机):

[3, 13, 17, 21, 23, 25]  2

生成随机字符:

package test;public class MathRandomChar {  public static char getRandomChar(char c1,char c2){    return (char)(c1+Math.random()*(c2-c1+1));     }  public static void main(String[] args) {    System.out.println("a-z之间的任意字符:  "+getRandomChar('a','z'));  }}

运行结果(随机):

a-z之间的任意字符:  g

2. java.util.Random方法

方法一:for循环加递归:

package test;import java.util.Random;import java.util.SortedSet;import java.util.TreeSet;public class Test {  static Random ran = new Random();  static SortedSet set = new TreeSet();  public static void randomSet(int n, int m) {    for (int i = 0; i < n; i++) {      set.add(ran.nextInt(33) + 1);    }    if (set.size() < m) {      randomSet(m - set.size(), m);    }  }  public static void main(String[] args) {    randomSet(6, 6);    System.out.print(set);    System.out.println(" "+(ran.nextInt(16)+1));  }}

运行结果(随机):

[1, 15, 18, 29, 30, 31] 13

方法二:while循环

package test;import java.util.Random;import java.util.Set;import java.util.TreeSet;public class ShuangSeQiu {  public static void main(String[] args) {    Random ran = new Random();    Set<Integer> set = new TreeSet<>();    while (true) {      int a = ran.nextInt(33) + 1;      set.add(a);      if (set.size() > 5) {        System.out.print(set);        break;      }    }    System.out.println(" "+(ran.nextInt(16)+1));  }}

运行结果(随机):

[2, 11, 12, 16, 23, 26] 7

 

希望本文所述对大家java程序设计有所帮助。


注:相关教程知识阅读请移步到JAVA教程频道。
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表