Publié le 15/07/2010
Auteur fobec
Réseaux sociaux
0 partages
0 tweets
0 plus
0 commentaires

Generer une suite aleatoire de chiffre sans doublon

Comment remplir un tableau d'entier avec des chiffres au hasard ?
En se servant de l'objet ArrayList et d'un tableau d'entier, les nombres sont mélangés sans qu'il y ait de doublons dans la série.

Comment remplir un tableau avec random sans doublon

Les deux techniques sont assez similaires pour ajouter des nombres dans un tableau sans avoir deux fois le meme. Avec la fonction Random, les chiffres sont pris aléatoirement dans un tableau préalablement remplit. Avec la package Collection, nous utilisons la fonction Shiffle pour mélanger les nombres contenus dans le tableau.

import java.util.ArrayList;
import java.util.Collections;
import java.util.Random;
 
/**
 * Générer une suite de chiffre aléatoire sans doublon
 * http://www.fobec.com/java/952/generer-une-suite-aleatoire-chiffre-sans-doublon.html
 * @author fobec 2010
 */
public class RandomGenerator {
 
    /**
     * Méthode 1 avec la fonction Random
     * @param _size
     * @return
     */
    public static int[] integerList1(int _size) {
        ArrayList<Integer> intList = new ArrayList<Integer>();
        for (int i = 1; i <= _size; i++) {
            intList.add(i);
        }
 
        int[] randomValues = new int[intList.size()];
        Random random = new Random();
        int pos = 0;
 
        while (intList.size() > 0) {
            pos = random.nextInt(intList.size());
            randomValues[intList.size() - 1] = intList.get(pos);
            intList.remove(pos);
        }
 
        return randomValues;
    }
 
    /**
     * Méthode 2 avec le package collection
     * @param _size
     * @return
     */
    public static int[] integerList2(int _size) {
        ArrayList<Integer> intList = new ArrayList<Integer>();
        for (int i = 1; i <= _size; i++) {
            intList.add(i);
        }
 
        Collections.shuffle(intList);
 
        int[] randomValues = new int[intList.size()];
        for (int i = 1; i < _size; i++) {
            randomValues[i] = intList.get(i);
        }
        return randomValues;
    } 
}

Obtenir 100 nombres aléatoires

Pour illustrer la génération de nombre aléatoire, exécutez la class ci-dessous avec les paramètres suivants.

/**
     * Exemple d'une suite de 100 chiffres aleatoires
     * @param args
     */
    public static void main(String[] args) {
        System.out.println("Methode 1");
        int[] numList = RandomGenerator.integerList1(100);
        for (int i = 0; i < numList.length; i++) {
            System.out.println(numList[i]);
        }
        System.out.println("Methode 2");
        numList = RandomGenerator.integerList2(100);
        for (int i = 0; i < numList.length; i++) {
            System.out.println(numList[i]);
        }
    }

Cet article est un exemple pour générer des nombres aléatoires sans doublon. Une amélioration pourrait etre l'ajout d'une valeur minimale et d'une valeur maximale pour obtenir des nombres compris dans un interval.

Ajouter un commentaire

Les champs marqués d'un * sont obligatoires, les adresses emails se sont pas publiées.

A lire aussi

Réseaux sociaux
Présentation de l'article
Catégorie
java - sources
Mise a jour
15/07/2010
Visualisation
vu 3796 fois
Public
Internaute
Auteur de la publication
Fobec
Admin
Auteur de 261 articles
|BIO_PSEUDO|
Commentaires récents

Publié par brayan dans logiciel

je vous retour modem ip pour configury net firwell

Publié par pidjey dans php5

J'ai bien lu mais c'est vraiment trop fort et trop dur pour le moment, je sais pas vraiment comprendre vos syntaxes, elles sont enormes et moi, je ne suis qu'encore un debutant en PHP et il faudrait p...

Publié par mfranca dans CMS

Bonjour, Excellent outil pour moi, très interessant pour mes recherches en amateur...
Merci pour cette création Olubil
Ciao ciao

Publié par agence cms open source dans tuto

Vu la multitude des outils de gestion de contenu Open Source, sélectionner l'un d'entre eux exige de réaliser une comparaison fine. Les lecteurs défendent les raisons de leurs cho...

Publié par FOBEC dans CMS

test
commentaire