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 :

Problème à propos d'un exercice


Sujet :

Python

  1. #1
    Nouveau Candidat au Club
    Profil pro
    Inscrit en
    Novembre 2013
    Messages
    6
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2013
    Messages : 6
    Points : 1
    Points
    1
    Par défaut Problème à propos d'un exercice
    Bonjour à tous,

    Etant nouveau dans le beau monde qu'est la programmation, quelques difficultés font surface.

    Dernièrement, j'ai été confronté à un exercice dont je n'ai pas pu trouvé la résolution, malgré avoir très bien compris l'énoncé. Le voici :

    Pouvez-vous m'aider à résoudre cet exercice svp? Merci beaucoup!

  2. #2
    Expert éminent
    Avatar de tyrtamos
    Homme Profil pro
    Retraité
    Inscrit en
    Décembre 2007
    Messages
    4 484
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2007
    Messages : 4 484
    Points : 9 286
    Points
    9 286
    Billets dans le blog
    6
    Par défaut
    Bonjour,

    L'exemple situé à la suite de l'énoncé est assez facile à comprendre. Mais je ne sais pas à quoi tu as droit comme instructions. Voilà comment je ferais à travers un exemple:

    Soit le nombre n = 123456789

    En chaine binaire, cela donne: b = bin(n) => "0b111010110111100110100010101"

    On retire les "0b" du début avec: b = b[2:] => "111010110111100110100010101"

    Prenons maintenant une chaine de 2 bits. Combien y a-t-il de façons de placer des "0" et des "1" dans une séquence de 2 bits: il y en a 2**2=4, soit "00", "01", "10", "11". Voilà comment on peut les trouver:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    nb = 2
    for x in range(0, 2**nb):
        s = bin(x)[2:].zfill(nb)
        print(s)
    Ce qui affiche bien les 4 chaines demandées:

    La méthode .zfill permet d'ajouter à gauche le "0" qui manque quand on trouve seulement "0" (=> "00") ou "1" (=>"01").

    Il ne reste plus qu'à compter le nombre de fois où chaque séquence de 2 bits est trouvée dans la chaine binaire de début. On peut le faire avec la méthode .count:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    b = "111010110111100110100010101"
    nb = 2
    for x in range(0, 2**nb):
        s = bin(x)[2:].zfill(nb)
        print(s, b.count(s))
    Ce qui donne ici:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    00 2
    01 8
    10 8
    11 5
    Ce qui veut dire qu'on a trouvé 2 fois la séquence "00", 8 fois la séquence "01", etc...

    Pour trouver la même chose avec 3 bits, on applique le même code avec nb=3, ce qui donne:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    000 1
    001 2
    010 3
    011 3
    100 2
    101 4
    110 4
    111 2
    etc...

    Il ne reste plus qu'à stocker ces résultats, les trier et les présenter comme le demande l'exo.

    Bon courage pour la suite!

  3. #3
    Expert éminent
    Avatar de tyrtamos
    Homme Profil pro
    Retraité
    Inscrit en
    Décembre 2007
    Messages
    4 484
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2007
    Messages : 4 484
    Points : 9 286
    Points
    9 286
    Billets dans le blog
    6
    Par défaut
    Juste un petit complément.

    Il n'est pas précisé dans l'énoncé si la recherche doit être faite avec ou sans recouvrement. Or, on ne trouve bien sûr pas le même résultat dans les 2 cas.

    Par exemple, imaginons "10001" et comptons les "00". la méthode count trouvera 1 seul motif parce que le 2e zéro ayant été pris dans le 1er comptage ne sera pas pris pour un second.

    Si on veut compter avec recouvrement, il faut tester chaque caractère séparément avec une boucle. Par exemple:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    b="01010010010001000111101100001010011001111000010010011110010000000"
    seq = "00"
     
    # comptage sans recouvrement
    print(seq, b.count("00"))
     
    # comptage avec recouvrement
    c = 0
    for i in range(0, len(b)-1):
        if b[i:i+2]==seq:
            c += 1
    print(seq, c)
    Ce qui affiche:


  4. #4
    Nouveau Candidat au Club
    Profil pro
    Inscrit en
    Novembre 2013
    Messages
    6
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2013
    Messages : 6
    Points : 1
    Points
    1
    Par défaut
    Merci beaucoup pour votre réponse, ça m'a beaucoup aidé!

Discussions similaires

  1. [NumPy] Problème à propos d'un exercice sur image binaire
    Par i.Polo dans le forum Calcul scientifique
    Réponses: 8
    Dernier message: 16/05/2014, 03h10
  2. Petit Problème à propos de window.location
    Par djun1 dans le forum VBScript
    Réponses: 10
    Dernier message: 24/11/2012, 22h34
  3. Problème de transport RO(exercice)
    Par jophar dans le forum Mathématiques
    Réponses: 1
    Dernier message: 06/11/2011, 15h04
  4. ASP petit problème à propos sur une boucle if
    Par nicodu59 dans le forum ASP
    Réponses: 2
    Dernier message: 02/08/2007, 11h21
  5. A propos d'un exercice au Tutoriel
    Par Spacy_green dans le forum Assembleur
    Réponses: 4
    Dernier message: 07/02/2006, 02h09

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