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 :

comment afficher un nombre en binaire avec printf ?


Sujet :

C

  1. #1
    Candidat au Club
    Profil pro
    Inscrit en
    Février 2004
    Messages
    2
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2004
    Messages : 2
    Points : 2
    Points
    2
    Par défaut comment afficher un nombre en binaire avec printf ?
    bonjour,
    commen afficher un nombre en binaire avec printf?
    decimal c'est %d ..... et pour le binaire?

  2. #2
    Vow
    Vow est déconnecté
    Membre expérimenté Avatar de Vow
    Inscrit en
    Janvier 2003
    Messages
    1 259
    Détails du profil
    Informations personnelles :
    Âge : 48

    Informations forums :
    Inscription : Janvier 2003
    Messages : 1 259
    Points : 1 584
    Points
    1 584
    Par défaut
    Ca n'existe pas

  3. #3
    Membre habitué
    Inscrit en
    Février 2004
    Messages
    363
    Détails du profil
    Informations forums :
    Inscription : Février 2004
    Messages : 363
    Points : 161
    Points
    161
    Par défaut
    voici une fonction:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    unsigned int dtobin(unsigned char h)
    {
    	double n;
       unsigned int b=0;
     
       for(n=0;n<=7;n++)
       {
           b+=(pow(10,n)*(h%2));
           h/=2;
       }
     
       return b;
    }
    puis printf("%d",dtobin(ton_nombre_allant_de_0_à_255));

    [Balises CODE ajoutées par Anomaly - Merci d'y penser à l'avenir]

  4. #4
    Candidat au Club
    Profil pro
    Inscrit en
    Février 2004
    Messages
    2
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2004
    Messages : 2
    Points : 2
    Points
    2
    Par défaut
    merci !

  5. #5
    Membre habitué

    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Décembre 2010
    Messages
    80
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Décembre 2010
    Messages : 80
    Points : 127
    Points
    127
    Par défaut une autre fonction plus rapide
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    void affichebin(unsigned n)
    {
    	unsigned bit = 0 ;
    	unsigned mask = 1 ;
    	for (int i = 0 ; i < 32 ; ++i)
    	{
    		bit = (n & mask) >> i ;
    		printf("%d", bit) ;
    		mask <<= 1 ;
    	}
    }
    Elle a le mérite de ne pas utiliser pow, ni de modulo, mais seulement des opérations bit à bit.

    Autre avantage : elle traite tous les entiers (donc ceux > 255 aussi!)

  6. #6
    Expert éminent sénior
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 381
    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 381
    Points : 41 581
    Points
    41 581
    Par défaut
    @bakonu: Ça, c'est du vrai Binaire Codé Décimal!

  7. #7
    Nouveau Candidat au Club
    Homme Profil pro
    Architecte technique
    Inscrit en
    Avril 2011
    Messages
    1
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Architecte technique
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Avril 2011
    Messages : 1
    Points : 1
    Points
    1
    Par défaut version qui compile en C avec gcc et qui affiche les bits dans le bon ordre
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    char* strbin(const unsigned int n, const short nbBits )
    {  
      unsigned bit = 0 ;
      unsigned mask = 1 ;
      char* buffer = calloc( nbBits + 1, sizeof( char ) );
      int i;
      for (i = 0 ; i < nbBits ; ++i) {
        bit = (n & mask) >> i ;
        buffer[ nbBits - 1 - i ] = (char)('0' + bit);
        mask <<= 1 ;
      }
      buffer[nbBits] = '\0';
      return buffer;
    }

  8. #8
    Membre expérimenté
    Profil pro
    Développeur en systèmes embarqués retraité
    Inscrit en
    Mars 2006
    Messages
    952
    Détails du profil
    Informations personnelles :
    Localisation : France, Bas Rhin (Alsace)

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

    Informations forums :
    Inscription : Mars 2006
    Messages : 952
    Points : 1 351
    Points
    1 351
    Par défaut
    Salut,

    Bakonu, ta fonction ne passe pas mes tests unitaires sauf erreur. Je l'ai modifiée pour ne pas inclure math, et elle passe les tests, ce que je ne m'explique d'ailleurs pas . Super idée, le Binaire Codé Décimal!

    A+

    Pfeuh

    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
    #include <stdlib.h>
    #include <stdio.h>
    #include <assert.h>
     
    unsigned int dtobin(unsigned char rawvalue)
    {
        unsigned int tempvalue = 0;
        unsigned int weight = 1;
        unsigned int counter = 0;
     
        while(counter < 8)
        {
            tempvalue += weight * (rawvalue % 2);
            rawvalue >>= 1;
            weight *= 10;
            counter++;
        }
        return tempvalue;
    }
    int main(void)
    {
        assert(dtobin(0) == 0);
        assert(dtobin(1) == 1);
        assert(dtobin(3) == 11);
        assert(dtobin(128) == 10000000);
        assert(dtobin(129) == 10000001);
        assert(dtobin(131) == 10000011);
        assert(dtobin(255) == 11111111);
        return 0;
    }

  9. #9
    Modérateur
    Avatar de Obsidian
    Homme Profil pro
    Développeur en systèmes embarqués
    Inscrit en
    Septembre 2007
    Messages
    7 400
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Développeur en systèmes embarqués
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2007
    Messages : 7 400
    Points : 23 777
    Points
    23 777
    Par défaut
    Convertir en binaire, ce n'est quand même pas très difficile. Tous les outils de manipulation de bits sont déjà proposés par le C. Nul besoin de passer par les fonctions de la lib mathématique.

    Voici encore une petite routine qui utilise un buffer statique, donc sans allocation/libération, mais qui n'est pas réentrante ni thread-safe. Elle tient en quatre lignes :

    Code C : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    char * bin (unsigned long int i)
    {
        static char buffer [1+sizeof (unsigned long int)*8] = { 0 };
        char *p=buffer-1+sizeof (unsigned long int)*8;
        do { *--p = '0' + (i & 1); i >>= 1; } while (i);
        return p;
    }

    Elle a l'avantage de ne pas renvoyer de zéros non-significatifs, d'afficher quand même le 0 quand le nombre est nul, et d'allouer automatiquement à la compilation l'espace nécessaire et suffisant pour représenter un type long int quelque soit la plate-forme.

    Et donc :

    Code C : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    #include <stdio.h>
     
    int main (void)
    {
         printf ("240 s'écrit %s en binaire.\n",bin(240));
         return 0;
    }

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

Discussions similaires

  1. Réponses: 18
    Dernier message: 06/10/2007, 18h03
  2. Comment formater un nombre autrement qu'avec format
    Par xduris dans le forum MATLAB
    Réponses: 3
    Dernier message: 27/06/2007, 17h29
  3. Réponses: 5
    Dernier message: 20/04/2007, 09h00
  4. Comment afficher le nombre de connectés?
    Par baleiney dans le forum Langage
    Réponses: 2
    Dernier message: 22/10/2006, 00h11
  5. Réponses: 8
    Dernier message: 06/04/2006, 09h01

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