向数组中填随机数
练习:创建一个长度为6的 int 型数组,要求取值为1~30,同时元素值各不相同我自己写了一个稀烂的代码,能运行,结果输出的元素值有重复的,改了半天也没该明白,代码越改越乱。。。求助!到底哪里错了
package com.home.exer;
/*
*创建一个长度为6的int型数组,
*要求取值为1~30,同时元素值各不相同
*
*/
public class RandomArrayExer {
public static void main(String[] args) {
//1.创建数组
int[] arr = new int;
//arr = (int)(Math.random() * 30) + 1;
for(int i = 0;i < 6;i++){//i=1
//2.1 给每个元素赋值
arr = (int)(Math.random() * 30) + 1;
for(int j = 0;j < i;j++){
//2.2 判断是否和前面的元素相等,如果是则重新赋值
if(arr == arr){
for(;;){
arr = (int)(Math.random() * 30) + 1;
if(arr != arr){
break;
}
}
}
}
}
//3.输出数组元素
for(int i = 0;i < 6;i++){
System.out.print(arr + "\t");
}
}
}
package com.home.exer;
/*
*创建一个长度为6的int型数组,
*要求取值为1~30,同时元素值各不相同
*
*/
public class RandomArrayExer {
public static void main(String[] args) {
int[] arr = new int;
for(int i = 0;i < 6;i++){
arr=(int)(Math.random() * 30) + 1;
for(int j=0;j<i;j++) {
if(arr==arr) {
i--;
break;
}
}
}
for(int i = 0;i<6;i++) {
System.out.print(arr+" ");
}
}
} {:5_97:}我的想法是只要和前边的重复了,就i--重新来过 洋洋痒 发表于 2021-3-29 04:54
我的想法是只要和前边的重复了,就i--重新来过
妙啊{:7_146:}这个思路简单
我一开始的想法是,和前面的重复了,就用一个循环重新赋值,直到和前面的元素不相等
肯定是循环有问题,我看了下同样思路的代码,往里面加了一个boolean型标记,用了两个break和一个continue,整得挺费劲的。但是不知道我的具体怎么出的错,拿着笔顺了半天也没整明白 Amarantos 发表于 2021-3-29 08:36
妙啊这个思路简单
我一开始的想法是,和前面的重复了,就用一个循环重新赋值,直到和前面的元 ...
{:5_108:}我的代码复制过来格式对齐有点那啥,你自己看着点格式对齐 到底哪里错了呢 自己看吧,详细注释,都在里面,建议楼主多使用现成方法,提高效率和代码可读性!
package com.lian.convert;
import com.alibaba.fastjson.JSON;
import java.util.Arrays;
/**
* @author :LSS
* @description: 创建一个长度为6的 int 型数组,要求取值为1~30,同时元素值各不相同
* @date :2021/3/31 17:47
*/
public class TestC {
public static void main(String[] args) {
//定义计数器,记录数组中元素个数
int nums = 0;
//定义长度为6的int型数组
int[] arrays = new int;
while (true) {
//如果元素个数超过6,跳出循环
if (nums > 5)
break;
//随机生成0~30的数并向上取整,之后转换为int类型
int random = (int) Math.ceil(Math.random() * 30);
//判断数组中是否已经存在该元素,如果不存在,将值放进数组中,计数器加一
if (!Arrays.asList(arrays).contains(random)) {
arrays = random;
nums++;
}
}
//打印查看数组
System.out.println(JSON.toJSONString(arrays));
}
}
连帅帅 发表于 2021-3-31 18:05
自己看吧,详细注释,都在里面,建议楼主多使用现成方法,提高效率和代码可读性!
好的,谢谢建议!
页:
[1]