有关类的使用,生成指定区间的随机数的原理
在使用之前先导包:
import java.util.Random;
利用生成不同类型的随机数
在定义随机变量类型前要输入
r = new ();声明
public static void main(String[] args) {
Random r = new Random();
//生成short类型
short num1 = (short)r.nextInt();
System.out.println(num1);
//生成int类型
int num2 = r.nextInt();
System.out.println(num2);
//生成long类型
long num3 = r.nextLong();
System.out.println(num3);
//生成float类型
float num4 = r.nextFloat();
System.out.println(num4);
//生成double类型
double num5 = r.nextDouble();
System.out.println(num5);
//生成char类型
char num6 = (char)r.nextInt();
System.out.println(num6);
生成效果如图:
特殊的比如byte类型的生成
java 找出数组中第n大的数_求数组a[m周边元素的和_java数组 n选m 组合][1]
我们可以看到在idea中的提示byte类型括号内是数组名
因此我们在用生成byte类型的数据时,可以先定义一个数组:
byte[] bytes = new byte[1];
r.nextBytes(bytes);
System.out.println(bytes[0]);
结果如下:
java 找出数组中第n大的数_java数组 n选m 组合_求数组a[m周边元素的和][2]
第一次在用这个方法时候有一个疑问,改变数组长度会怎么样:
byte[] bytes = new byte[100];
r.nextBytes(bytes);
for(byte a:bytes){
System.out.print(a+"\t");
}
结果如下,byte数组内所有的数都被随机生成的数填满:
生成指定区间随机数的原理
假设生成随机数的区间是[min,max),那么在定义变量时候所用的公式是这样的,以int类型为例:
int num2 = r.nextInt(max-min+1)+min;
至于为什么,我们可以从最简单的范围定义理解
int num2 = r.nextInt(20);
我们知道这样的式子代表num2生成的范围是[0,20),其实我们可以这样看int num2 = r.(20)+0;后面就是代表着区间起始的位置括号里面代表从这个位置开始一共有多少个数java数组 n选m 组合,所以是max-min,再加上最小值本身
生成两个区间组合中随机数的方法
我们先看这样一个题java数组 n选m 组合 有关random类的使用,生成指定区间的随机数的原理,小红的考试成绩是整数而且波动很大是[50,60)或者[80,100)之间,请随机生成小红的成绩。
我们可以连接头尾java数组 n选m 组合,然后如果落在中间的部分,就重新随机:
<p><pre>Random r = new Random();
int num = 0;
do{
num = r.nextInt(51)+50;
}while(num>=60&&num