鱼C论坛

 找回密码
 立即注册
查看: 5867|回复: 5

[已解决]关于一个将0-100随机数不重复的放进数组里的问题

[复制链接]
发表于 2021-6-1 19:32:19 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
import java.util.Random;
public class randomArray {
    public static void main(String[] args){
        Random random = new Random();
        int[] randomArray = new int [10];
        for(int i = 0; i < randomArray.length; i++) {
            randomArray[i] = random.nextInt(100);
        }
        for(int j = 0; j < randomArray.length - 1; j++) {
            for (int k = j + 1; k < randomArray.length; k++) {
                if (randomArray[j] == randomArray[k]) {
                    randomArray[k] = 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 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函数进行排序。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2021-6-2 13:55:59 | 显示全部楼层
因为你第二个random.nextInt没有指定范围
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

发表于 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[10];
        while (count < randomArray.length) {
            Arrays.sort(randomArray);
            int i = random.nextInt(100);
            if (Arrays.binarySearch(randomArray, i) < 0) {
                randomArray[randomArray.length - 1 - count] = i;
                count++;
            }
        }
        Arrays.sort(randomArray);
        System.out.println(Arrays.toString(randomArray));
    }
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2021-6-2 16:54:29 | 显示全部楼层

哇,我迷了
while (count < randomArray.length) {
            Arrays.sort(randomArray);
            int i = random.nextInt(100);
            if (Arrays.binarySearch(randomArray, i) < 0) {
                randomArray[randomArray.length - 1 - count] = i;
                count++;
            }
        }
这段代码是什么意思?尤其是Arrays.binarySearch(randomArray, i)
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 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函数进行排序。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

我6点之前一直在线,有什么不懂的问我
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-12-22 19:26

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表