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
[RIA SERVICES] INCLUDE ET DOMAINDATASOURCE[RIA SERVICES] INCLUDE ET DOMAINDATASOURCE par Audrey
Dans un de mes articles précédents , j'avais parlé des DomainDataSource avec RIA Services dans le cas d'une interface Maître - Détail. Dans le même principe, je vais parler d'une autre manière de mettre en forme ce cas d'interface avec RIA Services. Et po...
Cliquez pour lire la suite de l'article par Audrey ZUNE : VERSION ZUNE SOFTWARE V 4.2 ET LA SOCIALISATIONZUNE : VERSION ZUNE SOFTWARE V 4.2 ET LA SOCIALISATION par ROMELARD Fabrice
Une des nouveautés de la version V 3.0 était l'apparition de l'onglet Social qui ne fonctionnait que si le MarketPlace était activé sur son poste. Cela limitait donc son intérêt, car hors du cadre commercial USA-CANADA, peu de monde trouva...
Cliquez pour lire la suite de l'article par ROMELARD Fabrice PRATIQUE DE SILVERLIGHT PAR ERIC AMBROSIPRATIQUE DE SILVERLIGHT PAR ERIC AMBROSI par MPOWARE
Je viens de finir la lecture du dernier livre d'
Eric Ambrosi
éditions PEARSON
Son livre donne une approche pratique de Silverlight qui sera aussi bien comprise par le développeur que par le designeur.
Tous les aspects du développement RIA sont abor...
Cliquez pour lire la suite de l'article par MPOWARE APPRENDRE à DéVELOPPER POUR LES MOBILES AVEC LA NOUVELLE GéNéRATION .NETAPPRENDRE à DéVELOPPER POUR LES MOBILES AVEC LA NOUVELLE GéNéRATION .NET par odewit
2 déclinaisons de Silverlight et 2 déclinaisons de Mono permettent dorénavant (ou permettront prochainement) de développer des applications .NET mobiles pour les principales plates-formes du marché :
Silverlight pour Symbian, basé sur Silverlight 2...
Cliquez pour lire la suite de l'article par odewit ZUNE : NOUVELLE VERSION DU ZUNE SOFTWARE - V 4.2ZUNE : NOUVELLE VERSION DU ZUNE SOFTWARE - V 4.2 par ROMELARD Fabrice
Avec la dernière génération du lecteur MP3 de Microsoft, le ZUNE HD, Microsoft a publié une nouvelle version du logiciel pour PC. Ainsi, je me suis décidé à installer celle-ci sur mon Tablet PC ACER, comme toujours le logiciel est donc tél...
Cliquez pour lire la suite de l'article par ROMELARD Fabrice
Forum
RE : ESPEAK RE : ESPEAK par ghanim13
Cliquez pour lire la suite par ghanim13
Logiciels
Academy System (10.9.4.0)ACADEMY SYSTEM (10.9.4.0)Logiciel de gestion des établissements.
- élèves/étudiants (inscription, dossier, absence...)
-... Cliquez pour télécharger Academy System Xilisoft Convertisseur Vidéo Ultimate (5.1.39.0305)XILISOFT CONVERTISSEUR VIDéO ULTIMATE (5.1.39.0305)Xilisoft Convertisseur Vidéo Ultimate est un outil puissant de conversion vidéo, facile à utilise... Cliquez pour télécharger Xilisoft Convertisseur Vidéo Ultimate Xilisoft DVD Ripper Ultimate (5.0.64.0304)XILISOFT DVD RIPPER ULTIMATE (5.0.64.0304)Xilisoft DVD Ripper Ultimate est un logiciel excellent pour copier et convertir DVD vers presque ... Cliquez pour télécharger Xilisoft DVD Ripper Ultimate Rigs of Rods (63.3)RIGS OF RODS (63.3)c'est un jeu de multi-simulation camions,autobus voitures, avions, bateaux, hélicoptère avec défo... Cliquez pour télécharger Rigs of Rods
|