题目:
创建一个长度为6的int型数组,要求数组元素值在1~30之间,且是随机赋值。同时要求元素值各不相同。
这个题我是用java解的,涉及到java取一定范围内的随机值这个知识点,方法如下:
假设所求范围是[min,max]
表达式:random.nextInt(max) % (max-min+1) + min;
//用到这个类库
import java.util.Random;
class RandomNumber{
public static void main(String[] args){
int max = 20;
int min = 10;
Random random = new Random();
//此时产生的res数值范围值[10,20]
int res = random.nextInt(max) % (max-min+1) + min;
}
}
random.nextInt(max)这个方法产生的范围是[0,20],再取余(max-min+1)得到的是[0,10],再加上min就是[10,20]了(其实是[20,10],但由于只是想得到这个范围内的某个随机数,并不拘泥于真实的区间规范,所以[20,10]和[10,20]就是一样的了)。
实现代码:
package array.guigu.demo;
import java.util.Scanner;
import java.util.Random;
public class ArrayDemo03 {
public static void main(String[] args){
//声明一个数组
int[] distinctArray = new int[6];
//标识新产生的数字是否已存在在数组中
boolean isFlag = false;
Random random = new Random();
//控制随机值范围
int max = 30,min = 1;
//主的循环体,用来控制的生成数据的个数
for(int i = 0;i < distinctArray.length;i++) {
//产生一个[1,30]之内的随机数
int curNum = random.nextInt(max) % (max-min+1) + min;
//用来循环判断新产生的数值是否在数组中存在,直至新产生的数值不在数组中存在结束循环
while(true) {
//遍历数组,查找是否有重复值
for(int j = 0;j < distinctArray.length;j++) {
if(curNum == distinctArray[j]) {
isFlag = true; //存在重复值,isFlag置为true
break;
}
}
//isFlag如果为true,产生一个新的值。否则,不存在重复值,结束循环。
if(isFlag) {
curNum = random.nextInt(max) % (max-min+1) + min;
}else {
break;
}
//重置isFlag
isFlag = false;
}
//将符合要求的值存到数组中去
distinctArray[i] = curNum;
}
//打印结果
for(int i = 0;i < distinctArray.length;i++) {
System.out.println(distinctArray[i]);
}
}
}
第二种方式:
package array.guigu.demo;
public class ArrayDemo04 {
public static void main(String[] args) {
int[] distinctArray = new int[6];
for(int i= 0;i < distinctArray.length;i++) {
distinctArray[i] = (int) (Math.random() * 30) + 1;
for(int j = 0;j < i;j++) {
if(distinctArray[j] == distinctArray[i]) {
i--;
break;
}
}
}
for(int i = 0;i < distinctArray.length;i++) {
System.out.println(distinctArray[i]);
}
}
}