Boucle : Pour .. allant de ..

Kamloops -  
 kamloops -
Bonjour,

Je débute tout juste dans la programmation en python. Je m'exerce a faire des petits algorithme pour le moment.
J'essaye actuellement de faire une algorithme permettant de passer d'une base à un autre base. Par exemple passer d'un système binaire a un système octal.

N=input("Choisissez la base de départ : ")
c=input("Entrez le nombre à convertir : ")
M=input("Choisissez la base dans quelle base voulez vous convertir "+ c +" : ")

		## Le principe est de passer d'une base N quelconque en une base 10 puis de repasser en une base M.

c=list(c)
c=c[::-1]   #Inverse la liste
a=len(c)    #Détermine la longueur de la liste

i=0
S=0

for i in range(a):
        S=c[i]*N**i

print(S)


En faite ma boucle aurait pour but de faire la somme des termes du nombre fois la base de départ a la puissance i.
i représente chaque numéro de la liste.

En gros voici ce que je voudrais faire :
http://imageshack.us/a/img827/6461/daumequation13676078272.png

Le problème est que quand je fais ça, le résultat est une suite interminable de chiffre (tout dépend le nombre qu'on entre au départ)

Une idée ?

2 réponses

  1. tyrtamos Messages postés 4 Statut Membre 2
     
    Bonjour,

    En exécutant ton code, j'ai surtout des erreurs de type: mélange de nombres et de chaînes de caractères.

    Si je reprends ce que tu souhaites faire:

    Les données de départ:
    - les bases N et M doivent être des nombres: il faut donc convertir le résultat de input avec int()
    - c, dans le cas général, doit être une chaîne de caractère (exemple: "01101001")

    Pour convertir c en base 10 à partir de sa base N en appliquant ta formule, il ne faut pas prendre c[i] mais la valeur décimale du caractère c[i] dans la base N.

    Il faut donc une chaîne de caractère représentant tous les caractères permis dans la base N, ici pour N=16:

    chiffres = "0123456789ABCDEF"

    et il faut chercher la valeur décimale des caractères en calculant leur indice. Par exemple, chiffres.find("B") donnera la valeur 11 (=indice de "B" dans la chaîne).

    Corrigé comme ça, ça marche, mais en Python, il y a plus simple:
    - on pourrait faire le calcul sans avoir à inverser l'ordre des caractères, et sans avoir à calculer de puissances
    - plus simple encore, quelque soit la base de départ N (de 2 à 36), on peut convertir c en base 10 avec un simple c10 = int(c, N)

    Voilà le petit code que je te propose, qui est valable, tant pour N que pour M, pour les bases de 2 à 36. J'ai complété ton code avec la conversion dans la base M:

    #!/usr/bin/python
    # -*- coding: utf-8 -*-
    # Python 3.2
    
    N = int(input("Choisissez la base de départ : "))
    c = input("Entrez le nombre à convertir : ")
    M = int(input("Choisissez dans quelle base convertir "+ c +" : "))
    
    # chiffres permis dans les bases de numération de 2 à 36
    chiffres = "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"
    
    # conversion de c en base 10 => c10  (solution alternative: c10 = int(c, N))
    c = c[::-1]   #Inverse l'ordre des caractères dans la chaîne
    c10 = 0
    for i in range(len(c)):
        c10 += chiffres.find(c[i])*N**i
    
    # conversion de c10 en base M
    if c10==0:
        result = "0"
    else:
        result = ""
        q = c10
        while q!=0:
            q, r = divmod(q, M)
            result = chiffres[r] + result    
    
    # affichage du résultat
    print("résultat:", result)
    
    1
  2. kamloops
     
    Merci beaucoup de la réponse mais si j'ai réussi à le finir moi même. C'est très intéressant de voir une autre alternative qui de plus, est beaucoup mieux je vois. :)

    Au cas où, pour ceux qui voudrait, voici l'algorithme en entier que j'ai fait :
    http://fr.sourcepod.com/lnjurt77-18549
    0