Bibm@th

Forum de mathématiques - Bibm@th.net

Bienvenue dans les forums du site BibM@th, des forums où on dit Bonjour (Bonsoir), Merci, S'il vous plaît...

Vous n'êtes pas identifié(e).

#1 26-05-2009 17:23:08

yoshi
Modo Ferox
Inscription : 20-11-2005
Messages : 17 101

[Python] Programmation du Théorème des restes chinois

Bonjour,

Version Python, avec contrôles, de la dernière mouture TI 200 BASIC  :

#!/usr/bin/env python
# -*- coding: cp1252 -*-

from fractions import gcd

def xeuklid(a,b):
    # calcul de l'inverse modulo b du nombre a
    xs0, xs1, ys0, ys1, s, d = 1, 0, 0, 1, 1, b
    while b!=0:
        q, r = divmod(a,b)      
        a, b = b, r
        x, y = xs1, ys1
        xs1, ys1 = q*xs1 + xs0, q*ys1 + ys0
        xs0, ys0 = x, y
        s = -s
    return s*xs0 + ((1-s)//2)*d

def entree_entiers(a,vrai):
    try:
        entree=int(a)
        if entree >0:
            vrai=1
    except ValueError:
        vrai=0
    return entree,vrai

print()
print ()
print ("********************************************************************************")
print ("*        Résolution d'équations par le théorème des restes chinois             *")
print ("*                                  Voir :                                      *")
print ("* [url]http://www.bibmath.net/dico/index.php3?action=affiche&quoi=./c/chinois.html[/url]  *")
print ("********************************************************************************")
print ()
print ()
Modulos, Restes, Produits_partiels, Inverses, nb_equa, Mods_prod, Som_prod,a,vrai =[],[],[],[],0,1,0,"",0
while vrai != 1:
    a=input("De combien d'équations disposez-vous ? ")
    nb_equa,vrai=entree_entiers(a,0)
    if not vrai or nb_equa <2:
        print ("Entrée incorrecte, veillez recommencer")
print
for i in range(nb_equa):
    vrai,vrai2=0,0
    while vrai2 != 1:
        while vrai != 1:
            a=input("Entrer le reste  no "+str(i+1)+" : ")
            r,vrai=entree_entiers(a,0)
            if not vrai:
                print ("Entrée incorrecte, veillez recommencer")
        vrai=0
        while vrai != 1:
            a=input("Entrer le modulo no "+str(i+1)+" : ")
            m,vrai=entree_entiers(a,0)
            if not vrai or r >= m:
                print ("Entrée incorrecte, veillez recommencer")
        p=gcd(r,m)
        if p == 1:
            vrai2=1
        else:
            print ("Ces 2 nombres ne sont pas premiers entre eux, veillez recommencer")
    Restes.append(r)
    Modulos.append(m)
    print ("----------------------")
    Mods_prod*=m

print()
print ("                           Votre problème :")
print ("          Trouver le plus petit nombre entier naturel x tel que ")
for i in range(nb_equa):
    print ('            x = '+str(Restes[i])+'   (modulo '+str(Modulos[i])+")")
print()
print()
print ("                           **************")
print ("                           * Résolution *")
print ("                           **************")
print ()
print ("Le produit des modulos est :",Mods_prod)

for i in range(nb_equa):
    pp_i=Mods_prod//Modulos[i]
    print ("Produit_partiel n° "+str(i+1)+" : "+str(Mods_prod)+"/"+str(Modulos[i])+" = ",pp_i, end="")
    Produits_partiels.append(pp_i)
    inv_i= int(xeuklid(pp_i,Modulos[i]))
    print ("     L'inverse, modulo "+str(Modulos[i])+", de "+str(pp_i)+" est : ",inv_i)
    Som_prod+=Restes[i]*pp_i*inv_i
    Inverses.append(inv_i)


                                               
print ( )                                            
print ('                         On a alors  :')
for i in range(nb_equa):
    if i>0:
        print ("+",end="")
    print (str(Restes[i])+"*"+str(Produits_partiels[i])+"*"+str(Inverses[i]),end="")
print ("= "+str(Som_prod))
print ()
print ("                         Et enfin : ")
print ("              ",Som_prod,"modulo "+str(Mods_prod)+" =",Som_prod%Mods_prod)
 

Sorties


********************************************************************************
*        Résolution d'équations par le théorème des restes chinois             *
*                                  Voir :                                      *
* http://www.bibmath.net/dico/index.php3?action=affiche&quoi=./c/chinois.html  *
********************************************************************************


De combien d'équations disposez-vous ? 3
Entrer le reste  no 1 : 3
Entrer le modulo no 1 : 17
----------------------
Entrer le reste  no 2 : 4
Entrer le modulo no 2 : 11
----------------------
Entrer le reste  no 3 : 5
Entrer le modulo no 3 : 6
----------------------

                           Votre problème :
          Trouver le plus petit nombre entier naturel x tel que
            x = 3   (modulo 17)
            x = 4   (modulo 11)
            x = 5   (modulo 6)


                           **************
                           * Résolution *
                           **************

Le produit des modulos est : 1122
Produit_partiel n° 1 : 1122/17 =  66     L'inverse, modulo 17, de 66 est :  8
Produit_partiel n° 2 : 1122/11 =  102     L'inverse, modulo 11, de 102 est :  4
Produit_partiel n° 3 : 1122/6 =  187     L'inverse, modulo 6, de 187 est :  1

                         On a alors  :
3*66*8+4*102*4+5*187*1= 4151

                         Et enfin :
               4151 modulo 1122 = 785

@+

Dernière modification par yoshi (28-05-2009 16:15:07)


Arx Tarpeia Capitoli proxima...

Hors ligne

#2 28-05-2009 16:26:00

yoshi
Modo Ferox
Inscription : 20-11-2005
Messages : 17 101

Re : [Python] Programmation du Théorème des restes chinois

Bonjour à tous,

Une petite mise à jour mineure du code pour ajouter la démarche de résolution et la rendre apparente...
Ce code fonctionne avec un n ombre d'équations supérieur à 3 : testé avec 4.
Cela dit au delà de 6 la présentation risque fort d'être assez moche ;: mais ne dit-on pas :
"Qu'importe le flacon pourvu qu'on ait l'ivresse"

@+


Arx Tarpeia Capitoli proxima...

Hors ligne

#3 20-12-2022 20:06:55

yoshi
Modo Ferox
Inscription : 20-11-2005
Messages : 17 101

Re : [Python] Programmation du Théorème des restes chinois

Bonsoir,

Pour la branche Python 3.x :

#!/usr/bin/env python
# -*- coding: cp1252 -*-

from math import gcd

def Invmod(a,m):
    return pow(a,m-2,m)
 
def entree_entiers(a,vrai):
    try:
        entree=int(a)
        if entree >0:
            vrai=1
    except ValueError:
        vrai=0
    return entree,vrai

print()
print()
print( "********************************************************************************")
print( "*        Résolution d'équations par le théorème des restes chinois             *")
print( "*                                  Voir :                                      *")
print( "* http://www.bibmath.net/dico/index.php3?action=affiche&quoi=./c/chinois.html  *")
print( "********************************************************************************")
print()
print()
Modulos, Restes, Produits_partiels, Inverses, nb_equa, Mods_prod, Som_prod,a,vrai =[],[],[],[],0,1,0,"",0
while vrai != 1:
    a=input("De combien d'équations disposez-vous ? ")
    nb_equa,vrai=entree_entiers(a,0)
    if not vrai or nb_equa <2:
        print( "Entrée incorrecte, veillez recommencer")
print()
for i in range(nb_equa):
    vrai,vrai2=0,0
    while vrai2 != 1:
        while vrai != 1:
            a=input("Entrer le reste  no "+str(i+1)+" : ")
            r,vrai=entree_entiers(a,0)
            if not vrai:
                print( "Entrée incorrecte, veillez recommencer")
        vrai=0
        while vrai != 1:
            a=input("Entrer le modulo no "+str(i+1)+" : ")
            m,vrai=entree_entiers(a,0)
            if not vrai or r >= m:
                print( "Entrée incorrecte, veillez recommencer")
        p=gcd(r,m)
        if p == 1:
            vrai2=1
        else:
            print( "Ces 2 nombres ne sont pas premiers entre eux, veillez recommencer")
    Restes.append(r)
    Modulos.append(m)
    print( "----------------------")
    Mods_prod*=m
3
print()
print( "                           Votre problème :")
print( "          Trouver le plus petit nombre entier naturel x tel que ")
for i in range(nb_equa):
    print( '            x = '+str(Restes[i])+'   (modulo '+str(Modulos[i])+")")
print()
print()
print( "                           **************")
print( "                           * Résolution *")
print( "                           **************")
print()
print( "Le produit des modulos est :",Mods_prod)

for i in range(nb_equa):
    pp_i=Mods_prod//Modulos[i]
    print("Produit_partiel n° "+str(i+1)+" : "+str(Mods_prod)+"/"+str(Modulos[i])+" = ",pp_i,end=" ")
    Produits_partiels.append(pp_i)
    inv_i= Invmod(pp_i,Modulos[i])
    print( "     L'inverse, modulo "+str(Modulos[i])+", de "+str(pp_i)+" est : ",inv_i)
    Som_prod+=Restes[i]*pp_i*inv_i
    Inverses.append(inv_i)
                               
print()                                              
print( '                         On a alors  :')
for i in range(nb_equa):
    if i>0:
        print( "+",end=" ")
    print (str(Restes[i])+"*"+str(Produits_partiels[i])+"*"+str(Inverses[i]),end=" ")
print( "= "+str(Som_prod))
print()
print( "                         Et enfin : ")
print( "               x =",Som_prod,"modulo "+str(Mods_prod)+" =",Som_prod%Mods_prod)
print()
 

@+


Arx Tarpeia Capitoli proxima...

Hors ligne

Réponse rapide

Veuillez composer votre message et l'envoyer
Nom (obligatoire)

E-mail (obligatoire)

Message (obligatoire)

Programme anti-spam : Afin de lutter contre le spam, nous vous demandons de bien vouloir répondre à la question suivante. Après inscription sur le site, vous n'aurez plus à répondre à ces questions.

Quel est le résultat de l'opération suivante (donner le résultat en chiffres)?
soixante sept plus quaranteet un
Système anti-bot

Faites glisser le curseur de gauche à droite pour activer le bouton de confirmation.

Attention : Vous devez activer Javascript dans votre navigateur pour utiliser le système anti-bot.

Pied de page des forums