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 :

comparaison de deux grand nombres


Sujet :

C

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre actif
    Profil pro
    Inscrit en
    Novembre 2010
    Messages
    89
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2010
    Messages : 89
    Par défaut comparaison de deux grand nombres
    bonjour
    en fait ,le prof nous a corrigé une question sur le grand membre
    le question c est de comparé deux grands membre ,voila la solution
    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
    #define TAILLE 10
     
    char nombre[TAILLE];
    char nombre2[TAILLE];
    char res[TAILLE];
     
    char superieur(char *nb, char *nb2){
      int i;
      for(i=0;i<TAILLE;i++)
        if(nb[i]>nb2[i])
          return 1;
        else if(nb[i]<nb2[i])
          return 0;
      return 1;
    }
    je suis pas d accord avec c est qui a fait le prof ,si je prends par exemple nb 8 6 8 8 7
    et nb2 3 7 8 1 9
    il va retourné 0 cad que nb2>nb1 alors que c est faux

    en fait je me doute que le prof a raisoné comme ca ,est ce que je mal compris l ago??
    merci de m avoir m expliqué
    surtout pourqoi il retourne 1 qq soit le resultat

  2. #2
    Membre chevronné Avatar de seeme
    Profil pro
    Inscrit en
    Octobre 2005
    Messages
    430
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : France

    Informations forums :
    Inscription : Octobre 2005
    Messages : 430
    Par défaut
    Euh..

    Non, avec nb = 86887 et nb2 = 37819, il va retourner 1...

  3. #3
    Membre actif
    Profil pro
    Inscrit en
    Novembre 2010
    Messages
    89
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2010
    Messages : 89
    Par défaut
    Citation Envoyé par seeme Voir le message
    Euh..

    Non, avec nb = 86887 et nb2 = 37819, il va retourner 1...
    comment 1

  4. #4
    Membre chevronné Avatar de seeme
    Profil pro
    Inscrit en
    Octobre 2005
    Messages
    430
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : France

    Informations forums :
    Inscription : Octobre 2005
    Messages : 430
    Par défaut
    Si tu déroules l'algorithme, dès la première comparaison, tu vas avoir un return 1.

  5. #5
    Membre émérite Avatar de Steph_ng8
    Homme Profil pro
    Doctorant en Informatique
    Inscrit en
    Septembre 2010
    Messages
    677
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Doctorant en Informatique

    Informations forums :
    Inscription : Septembre 2010
    Messages : 677
    Par défaut
    Bonjour,
    Il suffit de dérouler l'algorithme.

    nb = "86887" et nb2 = "37819".
    Première itération, i = 0.
    Donc nb[i] = nb[0] = '8' et nb2[i] = nb2[0] = '3'.

    Est-ce que nb[i] > nb2[i] ?
    Jusqu'à preuve du contraire, 8 > 3, donc nb[i] > nb2[i], donc on rentre dans le premier « if ».

    Et là, on retourne « 1 ».


    En fait, cet algorithme compare deux par deux chaque chiffre des deux nombres (le premier chiffre du premier nombre avec le premier chiffre du second nombre, le deuxième chiffre du premier nombre avec le deuxième chiffre du second nombre, et ainsi de suite).
    Si les deux chiffres sont différents, alors on retourne « 0 » ou « 1 » selon que c'est le premier ou le second qui est le plus grand ; sinon, on continue avec les chiffres suivants.
    Lorsque tous les chiffres ont été comparés (sous-entendu sans qu'il soit possible de départager les deux nombres), c'est que les deux nombres sont égaux ; et alors on retourne « 1 ».

    Ce dernier point me fait penser que cette fonction devrait plutôt s'appeler « superieur_ou_egal », mais bon…


    Je remarque également que cette fonction ne marche que si les deux nombres ont exactement TAILLE chiffres.
    Autrement, le résultat a de grandes chances d'être faussé.

  6. #6
    Membre Expert
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Octobre 2008
    Messages
    1 515
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur développement logiciels

    Informations forums :
    Inscription : Octobre 2008
    Messages : 1 515
    Par défaut
    Attention avec des nombres de taille différente

  7. #7
    Membre chevronné Avatar de seeme
    Profil pro
    Inscrit en
    Octobre 2005
    Messages
    430
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : France

    Informations forums :
    Inscription : Octobre 2005
    Messages : 430
    Par défaut
    Citation Envoyé par matafan Voir le message
    Attention avec des nombres de taille différente
    Effectivement, j'imagine qu'il s'agit plus d'un cours d'algorithmie qu'autre chose, sinon bam droit dans le mur!

Discussions similaires

  1. comparaison entre deux nombres entier
    Par info.pascal dans le forum Débuter
    Réponses: 6
    Dernier message: 08/02/2013, 02h07
  2. problème liste affichage des deux plus grands nombres
    Par LeGenTleManfr dans le forum Général Python
    Réponses: 8
    Dernier message: 05/11/2012, 21h13
  3. comparaison entre deux nombres
    Par paul0chon dans le forum C
    Réponses: 1
    Dernier message: 05/03/2011, 01h52
  4. Réponses: 9
    Dernier message: 22/01/2011, 14h56
  5. Comparaison de deux nombres à virgule
    Par TangoZoulou dans le forum Langage
    Réponses: 6
    Dernier message: 08/06/2009, 00h06

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