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

Programmation multimédia/Jeux Python Discussion :

Master mind optimisation


Sujet :

Programmation multimédia/Jeux Python

  1. #1
    Futur Membre du Club
    Femme Profil pro
    Étudiant
    Inscrit en
    Avril 2019
    Messages
    6
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 26
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Avril 2019
    Messages : 6
    Points : 6
    Points
    6
    Par défaut Master mind optimisation
    Je suis débutante en python et je viens de réaliser un master mind où l'ordinateur doit trouver la combinaison secrète de l'utilisateur en un minimum de coups. Le code marche très bien et mon programme met en moyenne 4coups pour trouver la solutions mais j'aimerais savoir si je pouvais l'optimiser car un ami m'a dit que mon programme ne l'était pas du tout. Dans ce code les couleurs sont représenté par des chiffres de 1 à 6.
    Code : 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
    33
    34
    35
    36
    37
    38
    39
     
    def noir_blanc(a, nbl):
        b = []
        global possibility, bl, n
        for i in possibility:
            n = 0
            bl = 0
            for chiffre in range(4):
                if i[chiffre] == a[chiffre]:
                    n = n+1
            bl = min(a.count(1), i.count(1)) + min(a.count(2), i.count(2)) + min(a.count(3), i.count(3)) + min(a.count(4), i.count(4)) + min(a.count(5), i.count(5)) + min(a.count(6), i.count(6)) - n
            if n == nbl[0] and bl == nbl[1]:
                b.append(i)
        possibility = b
     
     
    a = [1, 1, 1, 1]
    possibility = []
    for i in range(1,7):
        for k in range (1,7):
            for j in range (1, 7):
                for l in range (1, 7):
                    possibility.append([i, k, j, l])
     
    for i in range(12):
        print("Voici mon hypothèse", a, " "*70, i+1)
        nbl = input("Nombre de chiffres bien placés puis nombre de bons chiffres mais mal placées")
        print("-"*100)
        nbl = list(nbl.replace(" ", ""))
        for j in range(2):
            nbl[j] = int(nbl[j])
        noir_blanc(a, nbl)
        if len(possibility)==1:
            print("je sais la réponse est", possibility[0], "j'ai trouvé en ", i+1, "coups")
            break
        if len(possibility)== 0:
            print("il semblerait qu'il n'y ait pas de réponse possible vous vous êtes peut etre trompé ")
            break
        a = possibility[0]

  2. #2
    Expert éminent sénior
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 287
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Manche (Basse Normandie)

    Informations professionnelles :
    Activité : Architecte technique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2008
    Messages : 21 287
    Points : 36 776
    Points
    36 776
    Par défaut
    Salut,

    Citation Envoyé par Aciee Voir le message
    mais j'aimerais savoir si je pouvais l'optimiser car un ami m'a dit que mon programme ne l'était pas du tout.
    Et votre ami vous a lancé çà à la figure sans prendre le temps de vous donner quelques pistes?

    De toutes façons, vous débutez: tous les codes que vous écrivez ne valent que par le temps que vous avez passé à les mettre au point et vous familiariser avec ce que programmer veut dire.
    Dans quelques mois, lorsque vous les relirez, vous compatirez de tout ce que vous ignoriez à l'époque où vous l'avez écrit.

    C'est le dilemme du débutant: avoir la fierté d'avoir écrit un code qui fonctionne avec la frustration d'ignorer tout ce qui pourrait aider à écrire un meilleur code...

    Pourquoi ne pas passer au chapitre suivant de votre tuto. et apprendre de nouvelles notions et vous promettre de relire votre code dans quelques semaines pour l'améliorer en fonction de ce que vous aurez appris...

    - W
    Architectures post-modernes.
    Python sur DVP c'est aussi des FAQs, des cours et tutoriels

Discussions similaires

  1. master mind 8 chiffres à deviner
    Par proff dans le forum Débuter
    Réponses: 3
    Dernier message: 24/12/2013, 11h33
  2. Optimisation de votre SGBDR et de vos requêtes...
    Par SQLpro dans le forum Langage SQL
    Réponses: 35
    Dernier message: 11/01/2013, 11h49
  3. [Débutant] Master mind (mode console)
    Par Lunalune dans le forum VB.NET
    Réponses: 2
    Dernier message: 09/12/2011, 08h31
  4. [langage]Problème de temps de lecture, optimisation
    Par And_the_problem_is dans le forum Langage
    Réponses: 2
    Dernier message: 08/01/2003, 08h47
  5. [langage] Optimiser la lecture d'un fichier
    Par And_the_problem_is dans le forum Langage
    Réponses: 2
    Dernier message: 11/06/2002, 10h24

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