WarSir 发表于 2021-6-1 19:32:19

关于一个将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”这种数字,求助。

连帅帅 发表于 2021-6-2 13:55:59

因为你第二个random.nextInt没有指定范围{:5_104:}

连帅帅 发表于 2021-6-2 14:56:37

本帖最后由 连帅帅 于 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));
    }

WarSir 发表于 2021-6-2 16:54:29

连帅帅 发表于 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:05:45

本帖最后由 连帅帅 于 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:06:41

连帅帅 发表于 2021-6-2 17:05
根据你数组大小,放入值,Arrays.binarySearch是Arrays库中的二分函数,第一个参数randomArray是要查找的 ...

我6点之前一直在线,有什么不懂的问我
页: [1]
查看完整版本: 关于一个将0-100随机数不重复的放进数组里的问题