Maison > Java > JavaBase > Comment générer n nombres aléatoires différents dans un intervalle spécifié en Java

Comment générer n nombres aléatoires différents dans un intervalle spécifié en Java

王林
Libérer: 2019-11-25 11:47:08
original
3650 Les gens l'ont consulté

Comment générer n nombres aléatoires différents dans un intervalle spécifié en Java

Méthode d'implémentation :

Définissez d'abord un tableau de longueur n, puis commencez à utiliser une boucle while pour générer des nombres aléatoires afin d'attribuer des valeurs au tableau Avant. en attribuant des valeurs, vous devez parcourir le tableau des valeurs existantes, s'il y a des valeurs égales, régénérer des nombres aléatoires sans attribuer de valeurs et effectuer une boucle jusqu'à ce que tous les tableaux définis soient attribués.

Les exemples sont les suivants :

 /**
    * 功能:产生min-max中的n个不重复的随机数
    * 
    * min:产生随机数的其实位置
    * mab:产生随机数的最大位置
    * n: 所要产生多少个随机数
    *
    */
    public static int[] randomNumber(int min,int max,int n){
        //判断是否已经达到索要输出随机数的个数
        if(n>(max-min+1) || max <min){
            return null;
        }
        int[] result = new int[n]; //用于存放结果的数组

        int count = 0;
        while(count <n){
            int num = (int)(Math.random()*(max-min))+min;
            boolean flag = true;
            for(int j=0;j<count;j++){
                if(num == result[j]){
                    flag = false;
                    break;
                }
            }
            if(flag){
                result[count] = num;
                count++;
            }
        }
        return result;
    }
Copier après la connexion

Recommandation vidéo d'apprentissage Java : Introduction au développement Java

En utilisant les caractéristiques de Set, les éléments ne peuvent pas être répétés

En utilisant les caractéristiques de Set, les éléments ne peuvent pas être répétés

/**
     * 功能:随机指定范围内N个不重复的数
     * 
     * @param min 指定范围最小值
     * @param max 指定范围最大值
     * @param n 随机数个数
     */
    public static int[] randomSet(int min, int max, int n) {
        Set<Integer> set = new HashSet<Integer>();
        int[] array = new int[n];
        for (; true;) {
            // 调用Math.random()方法
            int num = (int) (Math.random() * (max - min)) + min;

            // 将不同的数存入HashSet中
            set.add(num);
            // 如果存入的数小于指定生成的个数,则调用递归再生成剩余个数的随机数,如此循环,直到达到指定大小
            if (set.size() >= n) {
                break;
            }
        }
        int i = 0;
        for (int a : set) {
            array[i] = a;
            i++;
        }
        return array;
    }
Copier après la connexion
Mettez d'abord les nombres aléatoires générés dans l'ensemble, puis déterminez la taille de l'ensemble s'il ne dépasse pas la longueur requise, continuez la boucle. S'il a dépassé, sortez de la boucle et convertissez. l'ensemble dans un tableau. Plus de recommandations d'articles sur Java : Introduction au langage Java

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal