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 :

Sous liste filtré


Sujet :

Python

  1. #1
    Membre à l'essai
    Homme Profil pro
    Ingénieur d'étude
    Inscrit en
    Janvier 2016
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur d'étude

    Informations forums :
    Inscription : Janvier 2016
    Messages : 8
    Points : 10
    Points
    10
    Par défaut Sous liste filtré
    Bonjour,

    je commence à me mettre à Python et j'ai un petit problème algorithmique dont je n'arrive pas à me défaire.
    Je dois créer une fonction prenant une liste en argument et un certain nombre de trou possible, le résultat est une liste contenant toutes les listes faisable avec les trous.

    Par exemple si la list = [1, 2, 3, 4, 5] et le nombre de trou = 1 le résultat est:
    [[1, 2, 3, 4],
    [1, 2, 3, 5],
    [1, 2, 4, 5],
    [1, 3, 4, 5],
    [2, 3, 4, 5]]

    si le nombre de trou est de 2 alors le résultat est:
    [[1, 2, 3],
    [1, 2, 4],
    [1, 2, 5],
    [1, 3, 4],
    [1, 3, 5],
    [1, 4, 5],
    [2, 3, 4],
    [2, 3, 5],
    [2, 4, 5],
    [3, 4, 5]]

    J'ai réussi à faire une fonction qui marche de manière récursive mais elle est vraiment lente et contient des doublons que je dois retirer ensuite, ce qui gache encore plus les performances, et je ne vois pas comment le faire de manière itérative.
    Ca me semble assez basique mais je n'ai pas trouvé de fonction déjà implémenté et optimisé (car je peux avoir des listes et un nombre de trous très grand).
    Connaissez vous un module qui fasse cela ?

  2. #2
    Expert éminent
    Avatar de fred1599
    Homme Profil pro
    Lead Dev Python
    Inscrit en
    Juillet 2006
    Messages
    3 911
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Meurthe et Moselle (Lorraine)

    Informations professionnelles :
    Activité : Lead Dev Python
    Secteur : Arts - Culture

    Informations forums :
    Inscription : Juillet 2006
    Messages : 3 911
    Points : 7 294
    Points
    7 294
    Par défaut
    Avec le module itertools et le générateur combinations, ça va tout seul

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    >>> l = list(map(str, [1, 2, 3, 4, 5]))
    >>> for val in combinations(l, len(l)-1):
    ...     print(' '.join(val))
    ... 
    1 2 3 4
    1 2 3 5
    1 2 4 5
    1 3 4 5
    2 3 4 5
    Il y a plus qu'à créer la fonction pour généraliser ma démonstration, quelque soit la longueur de liste et le nombre de trous.

  3. #3
    Membre à l'essai
    Homme Profil pro
    Ingénieur d'étude
    Inscrit en
    Janvier 2016
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur d'étude

    Informations forums :
    Inscription : Janvier 2016
    Messages : 8
    Points : 10
    Points
    10
    Par défaut
    C'est exactement ça, merci beaucoup !
    Et pourquoi j'avais lu exactement cette page

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

Discussions similaires

  1. Réponses: 2
    Dernier message: 05/08/2015, 13h48
  2. Réponses: 5
    Dernier message: 25/02/2014, 17h40
  3. [AC-2010] Formulaire, appliquer un filtre à la sous-liste
    Par Christ0880 dans le forum Requêtes et SQL.
    Réponses: 6
    Dernier message: 27/10/2012, 10h00
  4. Réponses: 2
    Dernier message: 13/10/2005, 14h24
  5. Action sur sous-formulaire filtré
    Par thevenix dans le forum IHM
    Réponses: 4
    Dernier message: 20/06/2005, 00h39

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