IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Algorithmes et structures de données Discussion :

Génération de nombres aléatoires différents


Sujet :

Algorithmes et structures de données

  1. #1
    Membre régulier
    Profil pro
    Inscrit en
    Mars 2005
    Messages
    100
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2005
    Messages : 100
    Points : 91
    Points
    91
    Par défaut Génération de nombres aléatoires différents
    Bonjour,

    J'aurais besoin d'un tableau de 200k cases contenant chacun un chiffre entre 1 et 200k, dans un ordre aléatoire.

    Actuellement, j'ai un algo qui remplit le tableau au fur et à mesure, comme suit :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    trouvé=1		//indique si le nombre était déjà présent dans le tableau
     
    POUR i=1 à 200000, faire : 
    {
    <div style="margin-left:40px">nombre_aleatoire est un entier
    tant que (trouvé == 1) //tant qu'on n'a pas trouvé un nombre différent
    {
    <div style="margin-left:40px">nombre_aleatoire =hasard (1, 200000) //la fonction hasard génère un nombre aléatoire entre 1 et 200000 (les paramètres)
    trouvé = recherche_identique() //On recherche dans tout le tableau déjà rempli un nombre identique, renvoie 1 si trouvé, 0 si pas trouvé</div>}
    fin
    //A ce moment là on a le nombre aléatoire différent, qu'on met dans le tableau.
    tableau[i] = nombre_aleatoire</div>}
    fin
    En bref, on génère un nombre aléatoire, puis on regarde dans le tableau si il y est déjà. Si il y est déjà, on recommence (mais la fonction "hasard" peut nous ressortir le même nombre).

    Le problème est assez évident, si je me rappelle bien mes cours de maths, le temps de calcul augmente exponentiellement avec la taille du tableau à obtenir. Pire, le programme peut théoriquement prendre un temps "infini" (si la fonction "hasard" nous sort en continu le même chiffre présent dans le tableau).


    J'ai besoin de changer l'algo pour qu'il accepte de générer un tableau plus grand.
    J'avais pensé générer les nombre de 1 à X, puis les placer aléatoirement dans le tableau, en sautant les "cases" déjà remplies.


    En bref, j'aimerais bien savoir si vous connaissiez des algos peu coûteux en temps pour faire ce genre de chose.

    Merci d'avance

  2. #2
    Rédacteur
    Avatar de pseudocode
    Homme Profil pro
    Architecte système
    Inscrit en
    Décembre 2006
    Messages
    10 062
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Architecte système
    Secteur : Industrie

    Informations forums :
    Inscription : Décembre 2006
    Messages : 10 062
    Points : 16 081
    Points
    16 081
    Par défaut
    1. créer un tableau de 200k cases avec les nombres de 1 à 200k dans l'ordre
    2. mélanger les cases du tableau (algo shuffle)
    3. ne pas oublier de marquer la discussion comme "résolue".
    ALGORITHME (n.m.): Méthode complexe de résolution d'un problème simple.

  3. #3
    Membre régulier
    Profil pro
    Inscrit en
    Mars 2005
    Messages
    100
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2005
    Messages : 100
    Points : 91
    Points
    91
    Par défaut
    Ça aurait été parfait avec un petit lien pour le 2), genre ça

    Merci !

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Réponses: 10
    Dernier message: 19/01/2012, 12h56
  2. Nombres aléatoires différents
    Par fikou dans le forum VB.NET
    Réponses: 7
    Dernier message: 07/08/2007, 08h02
  3. Tirer 3 nombres aléatoires différents
    Par uado dans le forum ASP
    Réponses: 3
    Dernier message: 23/05/2006, 10h30
  4. Génération de n nombres aléatoires différents
    Par progfou dans le forum Probabilités
    Réponses: 3
    Dernier message: 13/12/2005, 18h29
  5. recherche algo de génération de nombre aléatoire
    Par Pascale38 dans le forum MFC
    Réponses: 2
    Dernier message: 26/01/2004, 14h20

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo