(java学习之路之重新开始)面试题:创建一个长度为6的int型数组,要求数组元素值在1~30之间,且是随机赋值。同时要求元素值各不相同。

题目:
创建一个长度为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]);
		}
	}
}
  • 4
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值