begin process at 2012 05 27 20:56:26
  Trouver un code source :
 
dans
 
Accueil > 

Code

 > 

Maths & Algorithmes

 > THÉORÈME CHINOIS

THÉORÈME CHINOIS


 Description

résolution d'un systéme de congruence à l'aide du théoreme chinois

Source

  • #include<stdio.h>
  • #include<stdlib.h>
  • #include<conio.h>
  • #define val 100
  • long pgdc (long a,long b);
  • long inverse (long a1, long b1);
  • /*-----program principal------*/
  • int main()
  • { void entete(); //declaration de la fction entete
  • int tab_a[val],tab_n[val],tab_q[val],tab_qq[val];
  • int nbr_eq,i,j,k;
  • long n=1,solution=0;
  • clrscr();
  • entete(); //appel de la fction entete
  • do{
  • printf("donnez le nombre d'equations qu'il ya dans votre systeme "); scanf("%d",&nbr_eq);
  • }while(nbr_eq<1 || nbr_eq>val);
  • /*------------saisie des ai et ni--------------*/
  • for(i=0;i<nbr_eq;i++)
  • {
  • printf("saisissez l'element a%d de l'equation%d ",i+1,i+1);
  • scanf("%d",&tab_a[i]);
  • }
  • printf("\n\tsaisie des modules parielles\n");
  • for(i=0;i<nbr_eq;i++)
  • {
  • printf("saisissez l'element n%d de l'equation%d ",i+1,i+1);
  • scanf("%d",&tab_n[i]);
  • }
  • /*--------------test si les ni sont premiers deux a deux------*/
  • for(i=0;i<nbr_eq-1;i++)
  • {
  • for(j=i+1;j<nbr_eq;j++)
  • { if(pgdc(tab_n[i],tab_n[j])!=1)
  • { cprintf("les elements %d et %d ne sont pas premiers ntre eux",tab_n[i],tab_n[j]);
  • printf("\nreprenez la saisie des ni\n");
  • for(k=0;k<nbr_eq;k++)
  • {
  • printf("saisissez l'element n%d de l'equation%d ",k+1,k+1);
  • scanf("%d",&tab_n[k]);
  • }
  • }
  • }
  • }
  • clrscr();entete();textbackground(BLACK);
  • /*------------affichage du systeme--------------*/
  • printf("\nle systeme saisi est");
  • for(i=0;i<nbr_eq;i++)
  • {textcolor(CYAN);printf("\n");
  • cprintf(" x=%d mod %d",tab_a[i],tab_n[i]);
  • }
  • /*-----------calcul du produit des ni-----------*/
  • for(i=0;i<nbr_eq;i++)
  • n*=tab_n[i];
  • printf("\nle n est %d",n);
  • //calcul et affichage des qi et qqi
  • printf("\nles qi sont: ");
  • for(i=0;i<nbr_eq;i++)
  • {
  • tab_q[i]=n/tab_n[i];
  • printf("q%d=%d\t",i+1,tab_q[i]);
  • }
  • printf("\nles inverses respectives des qi dans Zi sont: ");
  • for(i=0;i<nbr_eq;i++)
  • {
  • tab_qq[i]=inverse(tab_q[i],tab_n[i]);
  • printf("q'%d=%d\t",i+1,tab_qq[i]);
  • }
  • /*--------calcul solution finale-------------*/
  • for(i=0;i<nbr_eq;i++)
  • solution+=((tab_a[i])*(tab_q[i])*(tab_qq[i]));
  • solution%=n;
  • printf("\n\n"); textcolor(RED);textbackground(YELLOW);
  • cprintf("la solution de cette equation est %d",solution);
  • gotoxy(1,49);textcolor(CYAN);cprintf("taper une touche pour sortir...");
  • getch();
  • return 0;
  • }
  • /*------------definition de la fction inverse--------*/
  • long inverse (long a, long b)
  • {
  • long Ro=a,R1=b,q,r,i=0,Vo=0,V1=1,Uo=1,U1=0,V2,U2;
  • long vect_u[50];
  • do
  • {
  • q=Ro/R1; r=Ro-R1*q; Ro=R1; R1=r;
  • i++;
  • U2=Uo-q*U1; V2=Vo-q*V1;
  • Uo=U1; U1=U2;
  • Vo=V1; V1=V2;
  • vect_u[i]=U2;
  • }
  • while(r!=0);
  • if(vect_u[i-1]>0) return vect_u[i-1]%b;
  • else return b-(-vect_u[i-1])%b;
  • }
  • /*-----------definition de la fction pgdc--------------*/
  • long pgdc (long a,long b)
  • {long r0,r1,q1,i;
  • if (a==0 ) return b;
  • if (b==0 ) return a;
  • if (a>b)
  • {r0=a; r1=b;}
  • else {r0=b; r1=a;}
  • q1=r0/r1;
  • i=r0-q1*r1;
  • if (i==0)
  • return r1;
  • else
  • {
  • do
  • {
  • r0=r1;
  • r1=i;
  • q1=r0/r1;
  • i=r0-q1*r1;
  • }while (i!=0);
  • return r1;
  • }
  • }
  • /*-----------definition de l'entete-----------*/
  • void entete ()
  • { int a,b;
  • textcolor(RED);
  • gotoxy(10,2);cprintf("++-------------------------------------------------------------++");
  • gotoxy(10,3);cprintf("|+-------------------------------------------------------------+|"); a=wherex(); b=wherey();
  • gotoxy(10,4);cprintf("||"); gotoxy(10,5);cprintf("||"); gotoxy(a-2,b+2);cprintf("||");gotoxy(a-2,b+1);cprintf("||");
  • gotoxy(10,6);cprintf("|+-------------------------------------------------------------+|");
  • gotoxy(10,7);cprintf("+--------------------------------------------------------------++");
  • textbackground(WHITE);
  • textcolor(BLUE);gotoxy(15,4);
  • cprintf("CE PROGRAMME RESOUD UN SYSTEME DE CONGRUENCE D'ORDRE N"); gotoxy(23,5);
  • cprintf(" A L'AIDE DU THEOREME CHINOIS"); gotoxy(2,9);
  • }
#include<stdio.h>
#include<stdlib.h>
#include<conio.h>
#define val 100
long pgdc (long a,long b);
long inverse (long a1, long b1);

	      /*-----program principal------*/
int main()
{ void entete();      //declaration de la fction entete
  int tab_a[val],tab_n[val],tab_q[val],tab_qq[val];
  int nbr_eq,i,j,k;
  long n=1,solution=0;
  clrscr();
  entete();           //appel de la fction entete
  do{
  printf("donnez le nombre d'equations qu'il ya dans votre systeme  "); scanf("%d",&nbr_eq);
  }while(nbr_eq<1 || nbr_eq>val);

       /*------------saisie des ai et ni--------------*/
   for(i=0;i<nbr_eq;i++)
     {
       printf("saisissez l'element a%d de l'equation%d  ",i+1,i+1);
       scanf("%d",&tab_a[i]);
      }
      printf("\n\tsaisie des modules parielles\n");

    for(i=0;i<nbr_eq;i++)
     {
       printf("saisissez l'element n%d de l'equation%d  ",i+1,i+1);
       scanf("%d",&tab_n[i]);
     }
      
             /*--------------test si les ni sont  premiers deux a deux------*/
    for(i=0;i<nbr_eq-1;i++)
      {
	for(j=i+1;j<nbr_eq;j++)
	  { if(pgdc(tab_n[i],tab_n[j])!=1)
	     { cprintf("les elements %d et %d ne sont pas premiers ntre eux",tab_n[i],tab_n[j]);
	       printf("\nreprenez la saisie des ni\n");
	       for(k=0;k<nbr_eq;k++)
		{
		printf("saisissez l'element n%d de l'equation%d  ",k+1,k+1);
		scanf("%d",&tab_n[k]);
		}
	     }
	   }
      }

      clrscr();entete();textbackground(BLACK);
	       
             /*------------affichage du systeme--------------*/
     printf("\nle systeme saisi est");
     for(i=0;i<nbr_eq;i++)
       {textcolor(CYAN);printf("\n");
	cprintf("  x=%d mod %d",tab_a[i],tab_n[i]);

	}
	     
               /*-----------calcul du produit des ni-----------*/
      for(i=0;i<nbr_eq;i++)
	 n*=tab_n[i];
	 printf("\nle n est %d",n);
		       //calcul et affichage des qi et qqi
      printf("\nles qi sont:  ");
      for(i=0;i<nbr_eq;i++)
	 {
	   tab_q[i]=n/tab_n[i];
	   printf("q%d=%d\t",i+1,tab_q[i]);
	  }
      printf("\nles inverses respectives des qi dans Zi sont:  ");
      for(i=0;i<nbr_eq;i++)
	 {
	   tab_qq[i]=inverse(tab_q[i],tab_n[i]);
	   printf("q'%d=%d\t",i+1,tab_qq[i]);
	  }
		 /*--------calcul solution finale-------------*/
       for(i=0;i<nbr_eq;i++)
	  solution+=((tab_a[i])*(tab_q[i])*(tab_qq[i]));
	  solution%=n;
       printf("\n\n"); textcolor(RED);textbackground(YELLOW);
       cprintf("la solution de cette equation est %d",solution);
       gotoxy(1,49);textcolor(CYAN);cprintf("taper une touche pour sortir...");
       getch();
       return 0;
 }

    /*------------definition de la fction inverse--------*/

  long inverse (long a, long b)
{
 long Ro=a,R1=b,q,r,i=0,Vo=0,V1=1,Uo=1,U1=0,V2,U2;
 long vect_u[50];

do
{
q=Ro/R1;     r=Ro-R1*q;     Ro=R1;        R1=r;
i++;
U2=Uo-q*U1;       V2=Vo-q*V1;
Uo=U1;            U1=U2;
Vo=V1;            V1=V2;
vect_u[i]=U2;
}
while(r!=0);

 if(vect_u[i-1]>0)      return vect_u[i-1]%b;
 else                   return b-(-vect_u[i-1])%b;
}

	  /*-----------definition de la fction pgdc--------------*/

long pgdc (long a,long b)
{long r0,r1,q1,i;
 if (a==0 )         return b;
 if (b==0 )         return a;
 if (a>b)
  {r0=a;  r1=b;}
  else {r0=b; r1=a;}
 q1=r0/r1;
 i=r0-q1*r1;
 if (i==0)
  return r1;
  else
   {
     do
     {
      r0=r1;
      r1=i;
      q1=r0/r1;
      i=r0-q1*r1;
      }while (i!=0);
     return r1;
   }
 }
		   /*-----------definition de l'entete-----------*/
 void entete ()
 { int a,b;
   textcolor(RED);
   gotoxy(10,2);cprintf("++-------------------------------------------------------------++");
   gotoxy(10,3);cprintf("|+-------------------------------------------------------------+|"); a=wherex(); b=wherey();
   gotoxy(10,4);cprintf("||");  gotoxy(10,5);cprintf("||"); gotoxy(a-2,b+2);cprintf("||");gotoxy(a-2,b+1);cprintf("||");
   gotoxy(10,6);cprintf("|+-------------------------------------------------------------+|");
   gotoxy(10,7);cprintf("+--------------------------------------------------------------++");
   textbackground(WHITE);
   textcolor(BLUE);gotoxy(15,4);
   cprintf("CE PROGRAMME RESOUD UN SYSTEME DE CONGRUENCE D'ORDRE N"); gotoxy(23,5);
   cprintf(" A L'AIDE DU THEOREME CHINOIS"); gotoxy(2,9);
 }


 Conclusion

je suis encore débutant et vos suggestions seraient toujours les bienvenus


 Sources de la même categorie

Source avec Zip UN EXAMPLE D'APPLICATION EN CUDA DE L'ALGORITHME DE SCAN POU... par oguzaras
Source avec Zip Source avec une capture CHIFFREMENT DE VIGENERE par lajouad
Source avec Zip Source avec une capture ANALYSE SYNTAXIQUE par lajouad
Source avec Zip Source avec une capture STRUCTURE D'UNE MATRICE PAR LES LISTE LINÉAIRE (NON CONTUGUS... par benzarabel
Source avec Zip Source avec une capture DESSINER UNE ARBRE BINAIRE( MODE CONSOLE): par benzarabel

 Sources en rapport avec celle ci

Source avec Zip Source avec une capture CHIFFREMENT DE VIGENERE par lajouad
Source avec Zip Source avec une capture SYSTÈME SOLAIRE OPEN GL AVEC BIBLIOTHÈQUE GLUT : 5 PLANETES ... par gabule
Source avec Zip Source avec une capture EXPLORER WINDOWS SANS MFC par ebooserge
Source avec Zip ORDONNANCEUR DE PROCESSUS par badrsmimite
Source avec Zip PETIT CLIENT SERVEUR (SANS PARTIE RESEAU) UTILISANT LES IPC ... par Manolo76000

Commentaires et avis

Commentaire de ibaarabe le 01/11/2011 13:41:42

pourrez vous faire un code java du theoreme de reste de chinois, parce que je n'arrive pas a trouver le vrai code...

 Ajouter un commentaire


Discussions en rapport avec ce code source dans le forum

architecture systeme [ par gus ] Qu'est ce qu'une sémaphore?Qu'est ce que la mémoire partagée?Merci SYSTEME D'EXPLOITATION [ par nilufacou ] Je sais qu'il existe un et même plusieur système d'exploitation (de type Linux) qui sont sur un cd-rom et on boote dessus. Pas besoin de disque dur sa lancer une commande systeme sur un unix [ par Sioban ] Je souhaite lancer un commande systeme de type un "ls -l nom_du_fichier.dat" sur un serveur unix via mon PC(XP). (Pour avoir le nombre de ligne de cer Recherche : Résolution de systeme d'equation matricielle [ par julien81 ] Bonjour tlm En fait cette année j'ai un sujet pour mon projet annuel c'est de faire le prog pour resoudre un systeme d'equation avec des matrice (dime [TC++3.0] pb d'affichage de l'heure du systeme!!!!! [ par kobee12 ] J'ai essaye d'afficher l'heure du systeme avec la structure 'dostime_t'. Seulement a chaque fois que j'affiche l'heure il m'ecrit un truc du style : ' Le carnet d'adresse outlook et le C/C++ [ par zinotron ] Je suis a la recherche d'un systeme pour gerer le carnet d'adresse d'oulook en C.par ex-&gt; que ca puisse me sortir toutes les entrées du carnet, ou executer une commande systeme [ par anthraxx ] bonjour,je voulais savoir si quelqu'un connait un moyen d'éxecuter des commandes su systemes d'exploitation sous Windows, et d'en récupérer l'output.I A vore avis... [ par DeAtHCrAsH ] A votre avis quel est la solution la moins couteuse en ressource systeme pour declencher une procedure de mon application a un moment donné ?Je m'expl comment connaitre le systeme utilisé (XP, 2000, 98) [ par gege1024 ] voila, j'ai une appli MFC,mais je dois adapter le graphisme en fct du systeme windows d'ou sera executé mon programme.comment savoir si c'est XP,2000, Suppr une fenetre systeme [ par sephiro ] Bonjour,J'aimerai supprimer une fenetre window qui apparait lorsque l'on eneleve une clef USB sans prévenir window, ma 1er solution est de recevoir le


Nos sponsors


Sondage...

CalendriCode

Mai 2012
LMMJVSD
 123456
78910111213
14151617181920
21222324252627
28293031   

Consulter la suite du CalendriCode

Photothèque

A découvrir



 
Développement réalisé par Nicolas SOREL (Nix) avec l'aide de : Cyril DURAND et Emmanuel (EBArtSoft), Merci à Vincent pour ses précieux conseils.
CodeS-SourceS.com© Toute reproduction même partielle est interdite sauf accord écrit du Webmaster
CodeS-SourceS.com© est une marque déposée tous droits réservés

Google Coop CodeS-SourceS Google Coop CodeS-SourceS
Temps d'éxécution de la page : 0,437 sec (3)

Nous contacter | Annoncer sur CodeS-SourceS | Mentions légales