IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

 C Discussion :

Calcul des facteurs premiers d'un nombre entier


Sujet :

C

  1. #1
    Futur Membre du Club
    Profil pro
    Inscrit en
    Novembre 2012
    Messages
    5
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Secteur : Santé

    Informations forums :
    Inscription : Novembre 2012
    Messages : 5
    Points : 8
    Points
    8
    Par défaut Calcul des facteurs premiers d'un nombre entier
    bonjour je suis débutant en langage C j'ai un exercice a faire qui permet de calculer les facteurs premiers d'un nombre entier n saisi au clavier
    avec le synoptique suivant
    les variables
    entier n
    entier k
    
    début
        écrire<< décomposition d'un nombre en facteurs premiers>>
        écrire<<Introduire un nombre>0 >>
        lire n;
        tant que n>0 faire
        début
            écrire<< Facteurs Premiers>>
            tant n modulo 2 = 0 faire
            début
                écrire<<2>>
                n<--- n/2
            fin
            k <--- 3
            tant que n=1
            si(n modulo k=0) alors k vaut k+2
            sinon
            début
                écrire k
                n<--- n/k
            fin
            écrire<< Introduire un nombre>0>>
            lire n
    
        fin
    fin
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    #include <stdio.h>
    #include <stdlib.h>
     
     
    int main(int argc, char *argv[])
    {
    int n=0 , k=0;
    printf("Décomposition d'un nombre en facteurs premiers\n");
    printf("Introduire un nombre >0\n");
    scanf("%d",&n);
    while (n>0)
    {
        printf("Facteurs premiers\n");
        while (n%2==0)
        {
            printf("2\n");
            n=n/2;
        }
        k=3;
        while(n=1)
        {
            if(n%k==0)
            {
                k=k+2;
            }
            else
            {
                printf("%d",k);
            }
            printf("Introduire un nombre>0\n");
            scanf("%d",&n);
        }
    }
     
    return 0;
     
    }
    voici mon code explique moi mes erreurs
    merci beaucoup

  2. #2
    Expert éminent sénior
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 369
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 369
    Points : 41 519
    Points
    41 519
    Par défaut
    Bonjour,
    La principale erreur que je vois, c'est celle-ci:
    Tu as évité cet écueil pour le while(n%2==0), mais tu es tombé dans le piège ici.
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

  3. #3
    Expert éminent sénior
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 689
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 12 689
    Points : 30 983
    Points
    30 983
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par guillonnano Voir le message
    bonjour je suis débutant en langage C j'ai un exercice a faire qui permet de calculer les facteurs premiers d'un nombre entier n saisi au clavier
    avec le synoptique suivant
    les variables
    entier n
    entier k
    
    début
        écrire<< décomposition d'un nombre en facteurs premiers>>
        écrire<<Introduire un nombre>0 >>
        lire n;
        tant que n>0 faire
        début
            écrire<< Facteurs Premiers>>
            tant n modulo 2 = 0 faire
            début
                écrire<<2>>
                n<--- n/2
            fin
            k <--- 3
            tant que n=1
            si(n modulo k=0) alors k vaut k+2
            sinon
            début
                écrire k
                n<--- n/k
            fin
            écrire<< Introduire un nombre>0>>
            lire n
    
        fin
    fin
    Bonjour
    A mon avis, tu as une erreur dans ton algo (en rouge)...
    Mon Tutoriel sur la programmation «Python»
    Mon Tutoriel sur la programmation «Shell»
    Sinon il y en a pleins d'autres. N'oubliez pas non plus les différentes faq disponibles sur ce site
    Et on poste ses codes entre balises [code] et [/code]

  4. #4
    Futur Membre du Club
    Profil pro
    Inscrit en
    Novembre 2012
    Messages
    5
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Secteur : Santé

    Informations forums :
    Inscription : Novembre 2012
    Messages : 5
    Points : 8
    Points
    8
    Par défaut
    malheureusement pas d'erreur dans l 'ago c'est celui donné dans l 'exo
    c'est bien
    tant que n=1

  5. #5
    Membre régulier
    Profil pro
    Inscrit en
    Janvier 2014
    Messages
    142
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2014
    Messages : 142
    Points : 109
    Points
    109
    Par défaut
    Tout a fait d'accord sur ce que dit Sve@r et je pense bien qu'il y a d autres erreurs dans l algorithme...

    Ce k semble être destiné à accueillir les facteurs premiers potentiels de n.
    le test
    si(n modulo k=0)
    va donc le changer dès qu'il va diviser n.... ce qui ne me semble pas être le comportement approprié.

    De plus la valeur pour laquelle il est changé (on lui ajoute 2) ne sera pas toujours un nombre premier... ce qui n'est certainement pas le comportement espéré. (J'édite ici pour valider cet aspect de l'algo, même s'il va du coup faire pas mal de tests inutiles, proposer k+2 comme prochain facteur premier potentiel va bien provoquer le comportement voulu).

  6. #6
    Membre régulier
    Profil pro
    Inscrit en
    Janvier 2014
    Messages
    142
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2014
    Messages : 142
    Points : 109
    Points
    109
    Par défaut
    Si si cet algo contient au moins deux erreurs, il fera tout sauf décomposer n en facteurs premiers...

  7. #7
    Expert éminent sénior
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 689
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 12 689
    Points : 30 983
    Points
    30 983
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par guillonnano Voir le message
    malheureusement pas d'erreur dans l 'ago c'est celui donné dans l 'exo
    c'est bien
    tant que n=1
    Et alors ? Le fait que ce soit écrit t'empêche de réfléchir ??? Ne se peut-il pas qu'il y ait une erreur dans l'énoncé ???
    Partons par exemple avec n=50. Tu commences tant que (n%2) == 0; n=n/2 => ça donne n=25.
    Ensuite ben penses-tu vraiment boucler tant que 25 égal 1 ???

    Citation Envoyé par BaygonV Voir le message
    De plus la valeur pour laquelle il est changé (on lui ajoute 2) ne sera pas toujours un nombre premier... ce qui n'est certainement pas le comportement espéré.
    Sisi ça ça fonctionne. Si le nombre est divisible par 3 alors il sera divisé par 3 autant de fois que possible. Ensuite k passera à 5 (premier) puis 7 (premier) puis 9. 9 n'est certes pas premier mais comme 9 est lui-même divisible par 3 et que n aura été divisé par 3 tant que possible alors n ne sera pas divisible par 9 donc 9 sera testé mais non retenu. Ensuite k passera à 11 (premier) puis 13 (premier) puis 15 mais là aussi même histoire (les divisions par 3 et par 5 auront déjà été traitées donc 15 ne sera pas retenu comme diviseur). Et donc au final même si tous les nombres impairs auront été testés seuls les diviseurs premiers sortiront...
    Mon Tutoriel sur la programmation «Python»
    Mon Tutoriel sur la programmation «Shell»
    Sinon il y en a pleins d'autres. N'oubliez pas non plus les différentes faq disponibles sur ce site
    Et on poste ses codes entre balises [code] et [/code]

  8. #8
    Membre régulier
    Profil pro
    Inscrit en
    Janvier 2014
    Messages
    142
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2014
    Messages : 142
    Points : 109
    Points
    109
    Par défaut
    Oui oui Sve@r tout a fait d accord avec toi sur le fait que ca fonctionne (c était la raison de mon edit).

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Somme des N premiers nombres entiers positifs
    Par jujurochedu42 dans le forum Débuter
    Réponses: 2
    Dernier message: 26/09/2009, 23h58
  2. Réponses: 1
    Dernier message: 08/04/2009, 12h17
  3. Calcul des racines nième d'un nombre complexe donné
    Par lucaordi dans le forum Débuter
    Réponses: 4
    Dernier message: 02/08/2008, 21h01
  4. Réponses: 9
    Dernier message: 12/10/2006, 00h36
  5. [LG]Calcul des 15 premiers nombres premiers
    Par yffick dans le forum Langage
    Réponses: 12
    Dernier message: 18/09/2004, 14h57

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo