Accueil > > > THÉORÈME CHINOIS
THÉORÈME CHINOIS
Information sur la source
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
Commentaires et avis
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-> 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
|
Derniers Blogs
IMAGINE CUP 2012, MAKE A SIGN EN FINALEIMAGINE CUP 2012, MAKE A SIGN EN FINALE par junarnoalg
Voilà qui est fait, la nouvelle est officielle ! L'équipe belge "Make a Sign" va au pays des kangourous défendre son projet dans la catégorie Software Design. http://www.imaginecup.com/CompetitionsContent/Competition/WorldwideFinalists.aspx V...
Cliquez pour lire la suite de l'article par junarnoalg KINECT 1.5 IS OUT !KINECT 1.5 IS OUT ! par Vko
La version 1.5 du Kinect For Microsoft vient tout juste de sortir ! Plein de nouveautés: Tracking de squelette en Near Mode Détection en position assise Détection faciale avec un SDK dédié Documentation et des guideline (enfin) Un out...
Cliquez pour lire la suite de l'article par Vko LES ACTUALITéS DE LA SEMAINE SUR C2I.FR (14 MAI - 20 MAI) LES ACTUALITéS DE LA SEMAINE SUR C2I.FR (14 MAI - 20 MAI) par richardc
Mise à jour des Web API du 14 Mai
Réservez dès maintenant votre journée du 20 juin pour le Windows Azure Dev Camp 2012 à Paris
Mise à jour de Team Foundation Service
MechCommander 2 sur Windows 8
Entity Framework 5 Release Candidate e...
Cliquez pour lire la suite de l'article par richardc REACTIVE EXTENSIONS : CONSOMMER DES SERVICES AVEC RX PARTIE 3, LES PIèGES à éVITERREACTIVE EXTENSIONS : CONSOMMER DES SERVICES AVEC RX PARTIE 3, LES PIèGES à éVITER par Groc
Une mauvaise utilisation de rx lors de l'écriture d'une couche d'accès à des services peut conduire à des cas embarassants avec des erreurs mal gérées, des appels qui ne partent lorsqu'ils le devraient, et même des résultats incorrects . le tout nuis...
Cliquez pour lire la suite de l'article par Groc SHAREPOINT BLOG SITE, PROBLèME D'ARCHIVESSHAREPOINT BLOG SITE, PROBLèME D'ARCHIVES par junarnoalg
Dernièrement, nous avons migré le site
myTIC
vers un nouveau serveur SharePoint 2010. Dans les contenus que nous vouloins récupérer, nous avions un certain nombre de blogs.
Nous avons utilisé les commandes Power...
Cliquez pour lire la suite de l'article par junarnoalg
Forum
RE : SAC A DOS RE : SAC A DOS par hadjkaddour
Cliquez pour lire la suite par hadjkaddour
Logiciels
sDEVIS-FACTURES vlPRO (8.1.0.3)SDEVIS-FACTURES VLPRO (8.1.0.3)sDEVIS-FACTURES vlPRO a été mis au point pour les particuliers, créateurs, entrepreneurs, artisa... Cliquez pour télécharger sDEVIS-FACTURES vlPRO 974 Application Server (12.2.4.6)974 APPLICATION SERVER (12.2.4.6)Développez de puissantes applications dans un environnement de 'cloud computing', clusterisé, séc... Cliquez pour télécharger 974 Application Server vPicture (1.4.2.1)VPICTURE (1.4.2.1)Avec vPicture, hébergez vos images facilement et rapidement.
vPicture est un utilitaire simple, ... Cliquez pour télécharger vPicture Easy-Planning (2.2.1.6)EASY-PLANNING (2.2.1.6)Easy-Planning permet de créer des plannings sous la représentation de diagrammes et est adapté au... Cliquez pour télécharger Easy-Planning COM-BACKUP (2.0)COM-BACKUP (2.0)
COM-BACKUP est un logiciel de sauvegarde qui permet de planifier les sauvegardes de vos dossiers ...
Cliquez pour télécharger COM-BACKUP
|