Accueil > > > DÉCOMPOSITION D'UN NOMBRE EN PUISSANCE DE FACTEURS PREMIERS
DÉCOMPOSITION D'UN NOMBRE EN PUISSANCE DE FACTEURS PREMIERS
Information sur la source
Description
Enregistre dans une chaîne de caractère la décomposition d'un nombre en paramètres en facteurs premiers. le code est accompagne de deux fonctions qui ont leur equivalent dans string.h: addchaine() -> strcat() longeurChaine() -> strlen() (il est fort possible que vous les connaissiez) isPrime() verifie si le nombre est premier.
Source
- #include <math.h> //pour sqrt()
- #include <stdio.h>
- #include <stdlib.h>
-
- //Calcule le nombre de caractère d'une chaîne
- long longueurChaine(const char* chaine)
- {
- const char *c = chaine;
- while(*c) c++;
- return (c - chaine);
- }
-
- //Ajoute une chaîne à la suite d'une autre
- void addchaine(char* dest, const char* source)
- {
- while(*dest) dest++;
- while(*dest = *source)
- {
- dest++;
- source++;
- }
- }
-
- //Vérifie si le nombre est premier, renvoie 1 si vrai et 0 si faux
- int isPrime(long nombre)
- {
- if(nombre==1 || nombre==0)
- return 0;
- long i;
- //Verifie si le nombre a un diviseur autre que 1 et lui-même
- for(i = 2 ; i <= sqrt(nombre) ; i++)
- {
- if (nombre % i == 0)
- return 0;
- }
- return 1;
- }
-
- //Cherche la décomposition du nombre en puissance de facteurs premiers
- int factPrime(long nombre, char* chaine)
- {
- int k;
- //Efface la chaine
- for(k = 0 ; k < 100 ; k++)
- chaine[k]=0;
- char chainetmp[100]={'/0'};
- //Si le nombre est égale a 0, 1 ou est premier
- //il n'a pas de décomposition
- if (nombre == 0 || nombre == 1 || isPrime(nombre))
- sprintf(chaine,"%d", nombre) ;
- //Sinon
- else
- {
- long i;
- for(i = 2 ; i <= sqrt((double)nombre) ; i = i + 2)
- {
- int j = 0 ;
- //Calcule la puissance du diviseur en cour
- while (nombre % i == 0)
- {
- nombre /= i ;
- j++ ;
- }
- //Affiche le diviseur avec sa puissance
- if (nombre != 1)
- {
- if (j > 0)
- {
- if (j != 1)
- sprintf(chainetmp,"%ld^%d * ", i, j) ;
- if (j == 1)
- sprintf(chainetmp,"%ld * ", i) ;
- }
- }
- else
- //Affiche le dernier diviseur avec sa puissance (si different de 1)
- sprintf(chainetmp,"%ld^%d", i, j) ;
-
- if (i == 2)
- i--;
- if(j > 0)
- addchaine(chaine,chainetmp);
- int k;
- for(k = 0 ; k < 100 ; k++)
- chainetmp[k]=0;
- }
- //Affiche le dernier diviseur (si different de 1)
- if (nombre != 1)
- {
- sprintf(chainetmp,"%ld", nombre);
- addchaine(chaine,chainetmp);
- }
- }
- return 1;
- }
- int main()
- {
- long nb;
- char chaine[100]={0};
- printf("Entrez un nombre : ");
- scanf("%Ld",&nb);
- factPrime(nb,chaine);
- printf("%s\n",chaine);
- system("PAUSE");
- }
#include <math.h> //pour sqrt()
#include <stdio.h>
#include <stdlib.h>
//Calcule le nombre de caractère d'une chaîne
long longueurChaine(const char* chaine)
{
const char *c = chaine;
while(*c) c++;
return (c - chaine);
}
//Ajoute une chaîne à la suite d'une autre
void addchaine(char* dest, const char* source)
{
while(*dest) dest++;
while(*dest = *source)
{
dest++;
source++;
}
}
//Vérifie si le nombre est premier, renvoie 1 si vrai et 0 si faux
int isPrime(long nombre)
{
if(nombre==1 || nombre==0)
return 0;
long i;
//Verifie si le nombre a un diviseur autre que 1 et lui-même
for(i = 2 ; i <= sqrt(nombre) ; i++)
{
if (nombre % i == 0)
return 0;
}
return 1;
}
//Cherche la décomposition du nombre en puissance de facteurs premiers
int factPrime(long nombre, char* chaine)
{
int k;
//Efface la chaine
for(k = 0 ; k < 100 ; k++)
chaine[k]=0;
char chainetmp[100]={'/0'};
//Si le nombre est égale a 0, 1 ou est premier
//il n'a pas de décomposition
if (nombre == 0 || nombre == 1 || isPrime(nombre))
sprintf(chaine,"%d", nombre) ;
//Sinon
else
{
long i;
for(i = 2 ; i <= sqrt((double)nombre) ; i = i + 2)
{
int j = 0 ;
//Calcule la puissance du diviseur en cour
while (nombre % i == 0)
{
nombre /= i ;
j++ ;
}
//Affiche le diviseur avec sa puissance
if (nombre != 1)
{
if (j > 0)
{
if (j != 1)
sprintf(chainetmp,"%ld^%d * ", i, j) ;
if (j == 1)
sprintf(chainetmp,"%ld * ", i) ;
}
}
else
//Affiche le dernier diviseur avec sa puissance (si different de 1)
sprintf(chainetmp,"%ld^%d", i, j) ;
if (i == 2)
i--;
if(j > 0)
addchaine(chaine,chainetmp);
int k;
for(k = 0 ; k < 100 ; k++)
chainetmp[k]=0;
}
//Affiche le dernier diviseur (si different de 1)
if (nombre != 1)
{
sprintf(chainetmp,"%ld", nombre);
addchaine(chaine,chainetmp);
}
}
return 1;
}
int main()
{
long nb;
char chaine[100]={0};
printf("Entrez un nombre : ");
scanf("%Ld",&nb);
factPrime(nb,chaine);
printf("%s\n",chaine);
system("PAUSE");
}
Conclusion
c'est ma premiere source
Historique
- 14 novembre 2006 23:04:49 :
- menu en+
- 18 novembre 2006 17:24:12 :
- j'ai fais l'amelioration des fonction qui manipulent les chaine
Sources du même auteur
Sources de la même categorie
Commentaires et avis
Discussions en rapport avec ce code source dans le forum
premier prog C++ graphique et Dev C++ 4.0 [ par zoophage ]
Salut !je suis plus ou moins débutant en C++ et c'est pour ça que j'utilise dev c++ qui a le mérite d'être gratuit et facile à utiliser.Seulement, voi
Mettre une fenette en premier plan et l'activer [ par atao ]
QQun connait il une façon plus élégnate pour mettre une fenette en premier plan et l'activervoid MettreFenetreDevant(HWND hwndDlg){// car si elle est
Quelle API pour mettre en premier plan une autre fenetre ? [ par Kheo ]
Afin d'eviter d'avoir plusieurs instance de mon soft en memoire au tout debut j'effectue un FindWindow sur le titre de mon soft. S'il ne trouve rien j
connection entre deux projets [ par anaya ]
Salut tout le mondeje travaille sur deux projets, le premier c'est une plate forme ecrite en c++( ce qui m'interesse dans celle-la un seul variable" t
algorithme de gauss et decomposition LU [ par speedamine ]
bonjour a tous.je voudrai avoir des algorithmes ,ecrits en borland pascal,suivants:methode de gauss ordinaire pour la resolution d'un systeme .la deco
livres à proposer [ par chris5874 ]
bonjour!je voudrais vous faire part de 2 livres qui m'ont aidé à commencer,car je trouve,bien expliquésle premier s'appelle le language c++ en 21 jour
exercice tableau 2D pdcg et premier de deux entiers [ par ZeusRoot ]
Melook Media enr.Voici ma question : Je suis un debutant en C et je voudrais savoir comment aborder ce exercice.Enonce1.- Pour un nombre e
topmost sur une dialog [ par Manson ]
Salut a tous,voila je cree une dialog comme ceci :h_info = CreateDialog((HINSTANCE)hInst, MAKEINTRESOURCE(IDD_INFO), hWnd, (DLGPROC)MakeProcInstance((
[win32] forcer une fenetre a rester en premier plan [ par tcok ]
bonjour a tous,voila mon probleme, je developpe une application qui protege l'ordinateur sur lequel elle tourne, pendant l'absence de l'utilisateur, e
Premier mot d'une chaine [ par daivil ]
Bonsoir tout le monde,Je dois réaliser une fonction qui a le prototype suivnat :char *Premier (const T_Chaines ch);Et cette fonction doit me retourner
|
Derniers Blogs
CSS CONTENT STATE SELECTORS (PERSONNAL DRAFT)CSS CONTENT STATE SELECTORS (PERSONNAL DRAFT) par FREMYCOMPANY
Bonjour à tous, Je viens de publier une proposition comprenant 5 pseudo-classes pour le CSS Working Group ayant trait à l'état de chargement d'un élément (ex: IMG,VIDEO,AUDIO,OBJECT pour l'HTML.). Si le c½ur vous en dit, vous pouvez retrouver cette p...
Cliquez pour lire la suite de l'article par FREMYCOMPANY MBA : POURQUOI FAIRE ET COMMENT LE CHOISIR ?MBA : POURQUOI FAIRE ET COMMENT LE CHOISIR ? par ROMELARD Fabrice
Formation initiale Durant la formation, le découpage classique est le suivant (je donnerai les équivalences Suisse lorsque je les connaîtrais) : Ecole primaire jusqu'au Collège : Formation générale permettant d'obtenir les méthodes...
Cliquez pour lire la suite de l'article par ROMELARD Fabrice Y'A DES ERREURS QUI PEUVENT RENDRE LE DéVELOPPEUR VIOLENTY'A DES ERREURS QUI PEUVENT RENDRE LE DéVELOPPEUR VIOLENT par Aleks
Quand on a ce genre d'erreur sans log :
Et bas on a juste envie de choper le gas de Microsoft qu'a développé ça et lui foutre des baffes de Coboye ! ...
Cliquez pour lire la suite de l'article par Aleks [HYPER-V 3] PRéSENTATION DES COMMANDLETS POWERSHELL[HYPER-V 3] PRéSENTATION DES COMMANDLETS POWERSHELL par Pierrick CATRO-BROUILLET
Avec la sortie prochaine de la Beta Consumer Preview de Windows 8, j'avais envie de revenir sur une des fonctionnalités que j'attends le plus et que, en bon geek que je suis, j'utilise déjà : Hyper-V 3 ainsi son module PowerShell.
Il y a déjà pléthor...
Cliquez pour lire la suite de l'article par Pierrick CATRO-BROUILLET IIS7 - COMPRESSION GZIPIIS7 - COMPRESSION GZIP par cyril
La compression GZIP permet d'améliorer les performances de navigation en compressant ce qu'envoie le serveur à un client. Pour comprendre comment cela fonctionne, regardons ce qu'il se passe au niveau HTTP lorsqu'un client tente d'accéder à une ress...
Cliquez pour lire la suite de l'article par cyril
Forum
ARBRE BINAIREARBRE BINAIRE par pacotheking
Cliquez pour lire la suite par pacotheking
Logiciels
Easy-Planning (1.0.0.1)EASY-PLANNING (1.0.0.1)Basé sur les mêmes principes que MyPlanning, Easy-Planning permet de créer des plannings sous la ... Cliquez pour télécharger Easy-Planning Academy System (17.1.3.0)ACADEMY SYSTEM (17.1.3.0)Logiciel de gestion des établissements.
- élèves/étudiants (inscription, dossier, absence...)
-... Cliquez pour télécharger Academy System COLLECTOR PLUS (3.00B)COLLECTOR PLUS (3.00B)COLLECTOR PLUS version 3.00B est un logiciel utilisant une base de données alimentée par :
- L... Cliquez pour télécharger COLLECTOR PLUS PONAMEDIA PREMIUM - HELLLOOO FLASH DEMO (V7.4)PONAMEDIA PREMIUM - HELLLOOO FLASH DEMO (V7.4)PONAMEDIA TV DEVIENS HELLLOOO FLASH
LA TV SUR VOTRE ORDINATEUR.
Toute une plateforme Multi... Cliquez pour télécharger PONAMEDIA PREMIUM - HELLLOOO FLASH DEMO LettresFaciles 2011 (8.0.0.1)LETTRESFACILES 2011 (8.0.0.1)LettresFaciles est un logiciel facilitant la création et la rédaction de lettres types.
Son inte... Cliquez pour télécharger LettresFaciles 2011
|