关于一个将0-100随机数不重复的放进数组里的问题
import java.util.Random;public class randomArray {
public static void main(String[] args){
Random random = new Random();
int[] randomArray = new int ;
for(int i = 0; i < randomArray.length; i++) {
randomArray = random.nextInt(100);
}
for(int j = 0; j < randomArray.length - 1; j++) {
for (int k = j + 1; k < randomArray.length; k++) {
if (randomArray == randomArray) {
randomArray = random.nextInt();
}
}
}
for(int number:randomArray){
System.out.println(number + " ");
}
}
}
RUN:
3
72
23
24
1254754256
54
99
42
6
37
为什么会出现“1254754256”这种数字,求助。 因为你第二个random.nextInt没有指定范围{:5_104:} 本帖最后由 连帅帅 于 2021-6-2 14:57 编辑
连帅帅 发表于 2021-6-2 13:55
因为你第二个random.nextInt没有指定范围
补充一下代码:
public static void main(String[] args) {
int count = 0;
Random random = new Random();
int[] randomArray = new int;
while (count < randomArray.length) {
Arrays.sort(randomArray);
int i = random.nextInt(100);
if (Arrays.binarySearch(randomArray, i) < 0) {
randomArray = i;
count++;
}
}
Arrays.sort(randomArray);
System.out.println(Arrays.toString(randomArray));
} 连帅帅 发表于 2021-6-2 14:56
补充一下代码:
哇,我迷了
while (count < randomArray.length) {
Arrays.sort(randomArray);
int i = random.nextInt(100);
if (Arrays.binarySearch(randomArray, i) < 0) {
randomArray = i;
count++;
}
}
这段代码是什么意思?尤其是Arrays.binarySearch(randomArray, i) 本帖最后由 连帅帅 于 2021-6-2 17:07 编辑
WarSir 发表于 2021-6-2 16:54
哇,我迷了
while (count < randomArray.length) {
Arrays.sort(randomArray);
根据你数组大小,放入值,Arrays.binarySearch是Arrays库中的二分函数,第一个参数randomArray是要查找的数组,第二个是你要查找的值,如果存在返回元素下标,不存在返回应该存放的位置,是个负值,我用此判断数组中是否已经存在该值,如果小于0,则数组中不存在该值,赋值即可,同时count为计数器与数组元素下标,加一,该函数在使用之前必须是有序数组,所以使用Arrays.sort函数进行排序。 连帅帅 发表于 2021-6-2 17:05
根据你数组大小,放入值,Arrays.binarySearch是Arrays库中的二分函数,第一个参数randomArray是要查找的 ...
我6点之前一直在线,有什么不懂的问我
页:
[1]