JAVA生成6個1-8的隨機數,要求無重復。


算法題:生成不重復的隨機數]生成6個1-8的隨機數,要求無重復。先用數組保存隨機數,然后判斷是否重復,如果重復重新生成

方案一:

import java.util.Random;

public class Cai {
    public static void main(String[] args) {
        Random ran = new Random();
        int[] arr = new int[6];
        for(int i=0;i<arr.length;i++){ //生成6個無重復的隨機數
            arr[i] = ran.nextInt(33)+1; 
            for(int j=0;j<i;j++){
                if(arr[i] == arr[j]){ //和前面的重復了
                    i--; // 如果重復了,先 -- 后 ++ 相當於下標不向前移動
                    break;
                }
            }
        }
        for(int i=0;i<arr.length;i++){
            System.out.println(arr[i]);
        }
    }
}

方案二

import java.util.Random;

public class differenceOfRandom2 {
    public static void main(String[] args) {
        Random ran = new Random();
        int[] tmp = new int[8];
        for (int i = 0; i < tmp.length; i++) {
            tmp[i] = i + 1;
        } // tmp里面放了1 - 8
        int[] arr = new int[6];
        for (int i = 0; i < arr.length; i++) {
            int index = ran.nextInt(tmp.length - i); //
            System.out.println("index:" + index);
            arr[i] = tmp[index]; //隨機下標
            System.out.println("arr[i]:" + arr[i]);
            tmp[index] = tmp[tmp.length - 1 - i]; //
            System.out.println("tmp[index]:" + tmp[index]);
        }
        for (int i = 0; i < arr.length; i++) {
            System.out.println(arr[i]);
        }
    }
}

方案三:推薦使用

import java.util.Random;
import java.util.HashSet; //集合,自動過濾重復元素

public class Cai {
    public static void main(String[] args) {
        Random ran = new Random();
        HashSet hs = new HashSet();
        for(;;){
            int tmp = ran.nextInt(8)+1;
            hs.add(tmp);
            if(hs.size() == 6) break;
        }
        System.out.println(hs);
    }
}


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM