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

Python Discussion :

algo recursif à traduire


Sujet :

Python

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Inscrit en
    Septembre 2005
    Messages
    108
    Détails du profil
    Informations forums :
    Inscription : Septembre 2005
    Messages : 108
    Par défaut algo recursif à traduire
    bonjour bonjour,

    je cherche à ellaborer un algo qui donne, pour les éléments d'un tableau donné, l'ensemble des combinaisons de ces éléments.

    Ces combinaisons sont uniques (ab==ba) et on cherche dans les différentes tailles possibles(a,ab,abc)

    Je poste dans le forum python car j'ai trouvé un algo écrit en python qui fait ce dont j'ai besoin, mais malheureusement je suis néophyte en python et j'ai besoin d'appliquer cet algo en VB.

    voici l'algo:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
     
    def getCombi(items):
            res = []
            for n in xrange(1,len(items)+1):
                    res += combinationsUniques(items,n)
            return res
     
    def combinationsUniques(items, n):
            if n==0:
                    yield []
            else:
                    for i in xrange( len(items) - n+1 ):
                            for j in combinationsUniques( items[i+1:], n-1 ):
                                    yield [items[i]] + j
    J'ai compris que la méthode getCombi renvoi le tableau de combinaisons désiré correspondant au tableau items. Aussi, le méthode récursive combinatiosUniques consiste à chercher la liste des combinaisons uniques d’une taille n donnée, au sein d’une liste items.

    Mystère quant au yield, items[i+1:],yield [items[i]] + j et autre.

    donc en résumé si quelqu'un pourrait transcrire cet algo en pseudo-code, ce serait génial...

    Merci.

    boujou

  2. #2
    Membre confirmé
    Inscrit en
    Septembre 2005
    Messages
    108
    Détails du profil
    Informations forums :
    Inscription : Septembre 2005
    Messages : 108
    Par défaut
    apparement yield permet de retourner quelquechose, mais les manipulations de tableaux sont compliquées à comprendre.

  3. #3
    Membre Expert
    Homme Profil pro
    Inscrit en
    Mars 2007
    Messages
    941
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations forums :
    Inscription : Mars 2007
    Messages : 941
    Par défaut
    items[i+1:] = la sous-liste de items commençant au (i+1)ème élément jusqu'à la fin (le premier élément ayant l'indice 0).

    [items[i]] + j = concaténation d'une liste contenant un seul élément (le ième élément de items) et de la liste j. Cela revient à insérer l'éléments items[i] au début de la liste j.

    yield c'est la syntaxe des générateurs. Un générateur (ici, la fonction combinaisonUniques) est une fonction qui retourne un itérateur; à chaque fois qu'on appelle la méthode next de cet itérateur il continue l'exécution du corps de la fonction depuis le dernier yield jusqu'au yield suivant. Sans générateur, cela pourrait donner:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    def combinationsUniques(items, n):
        if n==0:
            return [[]]
        else:
            res = []
            for i in xrange( len(items) - n+1 ):
                for j in combinationsUniques( items[i+1:], n-1 ):
                    res.append([items[i]] + j)
            return res

  4. #4
    Membre confirmé
    Inscrit en
    Septembre 2005
    Messages
    108
    Détails du profil
    Informations forums :
    Inscription : Septembre 2005
    Messages : 108
    Par défaut
    Nickel. J'avais debrousaillé la gestion des tableaux mais yield je n'avais pas réussi. Ce système de générateur (auquel j'ai pas trop compris pour l'instant d'ailleurs) à l'air puissant.
    d'être tombé sur ce code m'à donné envie de m'y intéressé plus tard.
    En tous cas merci.

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

Discussions similaires

  1. Un algo recursif en Java ?
    Par ahmadou_20 dans le forum Débuter avec Java
    Réponses: 5
    Dernier message: 23/08/2014, 23h57
  2. traduire un algo en clair en code VBA
    Par jover dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 16/12/2007, 10h14

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