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 :

Correction programme de suite mathématique


Sujet :

C

  1. #1
    Nouveau Candidat au Club
    Inscrit en
    Novembre 2012
    Messages
    2
    Détails du profil
    Informations forums :
    Inscription : Novembre 2012
    Messages : 2
    Points : 1
    Points
    1
    Par défaut Correction programme de suite mathématique
    Bonsoir ,

    Mon programme permet d'afficher la somme de la suite S
    sans utiliser la fonction pow de la bibliotheque <<math.h>>
    avec S=1/2!+2/3!+3^2/4!+....+N^(N-1)/(N+1)!
    voila ce que j'ai fait:

    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
    #include <stdio.h>
     
    int main()
    {
        int j, i, s, s1, s2, somme, n;
     
        n = 1;
        s = 0;
        s1 = 0;
        s2 = 0;
     
        for (i = 1; i <= n; i++) {
            for (j = 1; j < i; j++)
                s1 = j * i;
            s2 = s2 * i;
            s = s1 / s2;
            somme = somme + s;
            n++;
        }
     
        printf("la somme de la suite est:%dn", somme);
    }
    J'aimerais bien que vous m'aidiez à corriger ce programme.
    Merci à tous

  2. #2
    Expert éminent
    Avatar de Melem
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Janvier 2006
    Messages
    3 656
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Électronique et micro-électronique

    Informations forums :
    Inscription : Janvier 2006
    Messages : 3 656
    Points : 8 389
    Points
    8 389
    Par défaut
    - Utilise des noms de variable décents (numerateur, denominateur, etc.).

    - La division d'un entier par un entier en C retourne un entier. Par exemple, 15 / 4 retourne 3 et non 3,75. 15.0 / 4 ou (15 * 1.0) / 4 par contre retournent bien 3,75. Tu dois donc corriger la manière dont tu écris tes opérations.

    - Le bon algorithme est :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    somme = 0
    numerateur = 0 /* Pour la beaute du code, mais ne sert a rien */
    denominateur = 1
     
    Pour i = 1 à N
        numerateur = puissance(i, i - 1) /* i ^ (i - 1) */
        denominateur = denominateur * (i + 1)
        somme = somme + (1.0 * numerateur) / denominateur
    Fin Pour
    On peut l'améliorer en calculant le numérateur incrémentalement, comme pour calculer le dénominateur, mais cela demande de connaître les formules de Pascal, puis de les implémenter. En gros c'est un petit peu plus compliqué, mais beaucoup plus performant.

    Il te reste à présent à traduire cette algorithme en C.

  3. #3
    Nouveau Candidat au Club
    Inscrit en
    Novembre 2012
    Messages
    2
    Détails du profil
    Informations forums :
    Inscription : Novembre 2012
    Messages : 2
    Points : 1
    Points
    1
    Par défaut
    oui merci mais je veux le faire sans utiliser la fonction pow(puissance) de la bibliotheque <<math.h>> et je ne sais pas comment faire pour le compiler
    pouvez vous m'aider il vous plait?????

  4. #4
    Modérateur

    Avatar de Bktero
    Homme Profil pro
    Développeur en systèmes embarqués
    Inscrit en
    Juin 2009
    Messages
    4 481
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur en systèmes embarqués

    Informations forums :
    Inscription : Juin 2009
    Messages : 4 481
    Points : 13 677
    Points
    13 677
    Billets dans le blog
    1
    Par défaut
    Qui a dit que puissance() de Melem était pow() de math.h ? Tu peux recoder une telle fonction, non ?

    @Melem : quelle est cette formule de Pascal ?

  5. #5
    Expert éminent
    Avatar de Melem
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Janvier 2006
    Messages
    3 656
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Électronique et micro-électronique

    Informations forums :
    Inscription : Janvier 2006
    Messages : 3 656
    Points : 8 389
    Points
    8 389
    Par défaut
    @Melem : quelle est cette formule de Pascal ?
    Je pensais qu'on pouvait trouver une relation de réccurence pour la suite U(n) = n ^ (n + 1). Si une telle relation existait, elle dépendrait sans doute des coefficients du triangle de Pascal. Malheureusement, après avoir bien regardé, elle n'existe pas .

  6. #6
    Expert éminent sénior
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 708
    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 708
    Points : 31 018
    Points
    31 018
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par Melem Voir le message
    Je pensais qu'on pouvait trouver une relation de réccurence pour la suite U(n) = n ^ (n + 1). Si une telle relation existait, elle dépendrait sans doute des coefficients du triangle de Pascal. Malheureusement, après avoir bien regardé, elle n'existe pas .
    En revanche on peut éviter de recalculer à chaque fraction la factorielle associée en utilisant la factorielle de la fraction précédente...
    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]

  7. #7
    Expert éminent
    Avatar de Melem
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Janvier 2006
    Messages
    3 656
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Électronique et micro-électronique

    Informations forums :
    Inscription : Janvier 2006
    Messages : 3 656
    Points : 8 389
    Points
    8 389
    Par défaut
    Oui, c'est ce qui est déjà fait .

Discussions similaires

  1. aide correction programme
    Par laureat dans le forum Débuter
    Réponses: 1
    Dernier message: 06/07/2011, 08h59
  2. Réponses: 2
    Dernier message: 02/03/2011, 13h30
  3. Lancer deux programmes à la suite
    Par stefsas dans le forum Macro
    Réponses: 2
    Dernier message: 22/08/2008, 16h42
  4. [TP] Programmation de suite
    Par anyone dans le forum Turbo Pascal
    Réponses: 4
    Dernier message: 27/09/2007, 11h43
  5. [C#] Comment correctement programmer orienté objet ?
    Par ChristopheOce dans le forum C#
    Réponses: 5
    Dernier message: 06/02/2006, 13h22

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