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 :

afficher toutes les combinaisons


Sujet :

Algorithmes et structures de données

  1. #1
    Débutant
    Inscrit en
    Mai 2009
    Messages
    392
    Détails du profil
    Informations forums :
    Inscription : Mai 2009
    Messages : 392
    Points : 35
    Points
    35
    Par défaut afficher toutes les combinaisons
    Bonjour,

    Je voulais afficher toutes les combinaisons possibles de taille 2, de taille 3 jusqu'à taille N.
    par exemple on a 4 mots(chaine de caractère):

    un
    deux
    trois
    quatre

    les combinaisons possibles de taille 2 jusqu'à taille 4 sont :

    un deux
    un trois
    un quatre
    deux trois
    deux quatre
    trois quatre
    un deux trois
    un deux quatre
    un trois quatre
    deux trois quatre
    un deux trois quatre
    On a N = 4 et le nombre de combinaisons = 11

    Avez vous une idée?


    Merci.

  2. #2
    Expert éminent
    Avatar de Jedai
    Homme Profil pro
    Enseignant
    Inscrit en
    Avril 2003
    Messages
    6 245
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Côte d'Or (Bourgogne)

    Informations professionnelles :
    Activité : Enseignant

    Informations forums :
    Inscription : Avril 2003
    Messages : 6 245
    Points : 8 586
    Points
    8 586
    Par défaut
    C'est l'ensemble des parties de taillle donnée ton algorithme. Tu peux faire ça récursivement :
    Code Haskell : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    nparts :: Int -> [a] -> [[a]]
    nparts 0 _ = [[]]
    nparts n xs = [y : ys | y : tl <- tails xs, ys <- nparts (n-1) tl]

    Autrement dit :
    Code Algo : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    nparts(0,anything) = {emptyset}
    nparts(n, {x1..xk}) = { {xi} U subpart / i in [1,k], subpart in nparts(n-1, {x(i+1)..xk} }

    Après tu peux juste faire l'union des nparts(2..4) ou adapter cet algo pour éviter de recalculer plusieurs fois les mêmes tailles.

    --
    Jedaï

  3. #3
    Débutant
    Inscrit en
    Mai 2009
    Messages
    392
    Détails du profil
    Informations forums :
    Inscription : Mai 2009
    Messages : 392
    Points : 35
    Points
    35
    Par défaut
    Bonjour,

    J'ai trouvé dans cette solution dans le net:

    Code C : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    #include <stdio.h>
    #define N 5
    void afficher(int etat[], char *t[])
    {
      int i;
      for (i = 0; i < N; i++)
        if (etat[i])
          printf("%s ", t[i]);
      puts("");
    }
     
    void partie(int h, int etat[], char *t[])
    {
      enum { ABSENT, PRESENT };
      if (h < 0)
        afficher(etat, t);
      else
        {
          etat[h] = ABSENT;
          partie(h - 1, etat, t);
          etat[h] = PRESENT;
          partie(h - 1, etat, t);
        }
    }
     
    int main(void)
    {
      char *t[N] = { "nom", "prenom", "age", "adresse", "emploi" };
      int etat[N];
      partie(N - 1, etat, t);
      return 0;
    }


    - Je ne sais pas pourquoi le résultat n'affiche pas les combinaisons dans l'ordre taille2, taille3,taille4,taille5 ?

    - Quelles modification à faire pour obtenir les combinaisons dans l'ordre car ceci m'aider à ne parcourir toutes les combinaisons par exemple si je voulais parcourir jusqu'à taille2 alors je boucle seulement jusqu'à taille 2 ?

    Je vois que le code de cette solution est réduit. Est ce que c'est la meilleure solution au niveau la moins consommation en mémoire par rapport aux autres solutions ?

    Merci.

  4. #4
    Expert éminent sénior

    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    10 610
    Détails du profil
    Informations personnelles :
    Âge : 66
    Localisation : France

    Informations forums :
    Inscription : Janvier 2007
    Messages : 10 610
    Points : 17 923
    Points
    17 923
    Billets dans le blog
    2
    Par défaut
    c'est pas beau de poster en double


    Maintenant, comme je te l'ai dit sur le forum C, si tu écrivais EN TEXTE ton algprithme en faisant marcher ton cerveau et ta rflexion au lieu de prendre un code récupéré et de le modifier, cela fait déjà un moment que tu aurais la solution..

    Et ici, sur ce forum Algorithme, on ne s'occupe pas du code mais de la description de l'algorithme..

    Ce qu'on attend de toi

Discussions similaires

  1. Réponses: 23
    Dernier message: 18/02/2010, 15h42
  2. Afficher toutes les combinaisons possibles
    Par NELLLY dans le forum MATLAB
    Réponses: 1
    Dernier message: 07/01/2008, 21h09
  3. Réponses: 1
    Dernier message: 29/11/2005, 00h37
  4. Lister toutes les combinaisons...
    Par monstroplante dans le forum Algorithmes et structures de données
    Réponses: 2
    Dernier message: 04/11/2005, 21h10

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