Langage C/C++

Conversion Hexadécimal en Binaire en Langage C : Exercices Corrigés et Cas Particuliers

La conversion des nombres hexadécimaux en binaire est une compétence essentielle en programmation, notamment en C. Cet article vise à fournir une explication détaillée de cette conversion, suivie d’exercices corrigés et de cas particuliers pour renforcer la compréhension.

1. Introduction à la Conversion Hexadécimal en Binaire

Les nombres hexadécimaux (base 16) sont couramment utilisés en informatique en raison de leur efficacité pour représenter des nombres binaires (base 2). Chaque chiffre hexadécimal correspond exactement à quatre bits binaires.

Table de Correspondance

HexadécimalBinaire
00000
10001
20010
30011
40100
50101
60110
70111
81000
91001
A1010
B1011
C1100
D1101
E1110
F1111
2. Conversion Manuelle

Pour convertir un nombre hexadécimal en binaire, il suffit de remplacer chaque chiffre hexadécimal par son équivalent binaire à 4 bits.

Exemple : Convertir 2F3 en binaire.

  1. 2 en binaire est 0010
  2. F en binaire est 1111
  3. 3 en binaire est 0011

Donc, 2F3 en hexadécimal est 0010 1111 0011 en binaire.

3. Programme en Langage C

Voici un programme en C qui effectue la conversion d’un nombre hexadécimal en binaire.

#include <stdio.h>
#include <string.h>

void hexToBinary(char hex[]) {
    int i = 0;
    printf("Binaire: ");
    while (hex[i]) {
        switch (hex[i]) {
            case '0': printf("0000"); break;
            case '1': printf("0001"); break;
            case '2': printf("0010"); break;
            case '3': printf("0011"); break;
            case '4': printf("0100"); break;
            case '5': printf("0101"); break;
            case '6': printf("0110"); break;
            case '7': printf("0111"); break;
            case '8': printf("1000"); break;
            case '9': printf("1001"); break;
            case 'A':
            case 'a': printf("1010"); break;
            case 'B':
            case 'b': printf("1011"); break;
            case 'C':
            case 'c': printf("1100"); break;
            case 'D':
            case 'd': printf("1101"); break;
            case 'E':
            case 'e': printf("1110"); break;
            case 'F':
            case 'f': printf("1111"); break;
            default: printf("\nCaractère hexadécimal invalide %c", hex[i]);
        }
        i++;
    }
    printf("\n");
}

int main() {
    char hex[100];
    printf("Entrer un nombre hexadécimal: ");
    scanf("%s", hex);
    hexToBinary(hex);
    return 0;
}
4. Exercices Corrigés

Exercice 1

Question: Convertir le nombre hexadécimal 1A3 en binaire.

Solution: 1A3 en hexadécimal est 0001 1010 0011 en binaire.

Exercice 2

Question: Convertir le nombre hexadécimal B7F en binaire.

Solution: B7F en hexadécimal est 1011 0111 1111 en binaire.

5. Cas Particuliers

Cas 1 : Nombres avec des zéros initiaux

Question: Convertir 05C en binaire.

Solution: 05C en hexadécimal est 0000 0101 1100 en binaire.

Cas 2 : Utilisation de lettres minuscules

Question: Convertir a2B en binaire.

Solution: a2B en hexadécimal est 1010 0010 1011 en binaire.

6. Conclusion

La conversion hexadécimale en binaire est un processus direct une fois la table de correspondance maîtrisée. Le programme en langage C présenté permet de réaliser cette conversion de manière automatique. Les exercices et cas particuliers illustrent les différentes nuances de cette conversion.

7. Références

Pour plus de lecture sur la conversion des systèmes de numération et la programmation en C, consultez les ressources suivantes :

  1. Guide de programmation en C
  2. Documentation sur les systèmes de numération

Exercices Avancés de Conversion Hexadécimale en Binaire en Langage C

Voici une série d’exercices avancés pour vous aider à maîtriser la conversion de nombres hexadécimaux en binaire en utilisant le langage de programmation C. Ces exercices comprennent des conversions directes, des manipulations de chaînes de caractères, et des cas particuliers qui vous permettront de consolider vos compétences.

Exercice 1 : Conversion de Longs Nombres Hexadécimaux

Question : Écrire un programme en C qui convertit un long nombre hexadécimal en binaire et affiche le résultat. Par exemple, convertir 1A3F4C2B en binaire.

Solution Attendue :

// Long hexadécimal : 1A3F4C2B
// Binaire attendu : 0001 1010 0011 1111 0100 1100 0010 1011
Exercice 2 : Conversion avec Validation

Question : Écrire un programme en C qui convertit un nombre hexadécimal en binaire. Le programme doit valider que l’entrée est bien un nombre hexadécimal valide (comprenant seulement les caractères 0-9, A-F, a-f) avant de faire la conversion.

Solution Attendue :

// Entrée : G45
// Sortie : Erreur, caractère invalide G
Exercice 3 : Conversion et Comptage de Bits

Question : Écrire un programme en C qui convertit un nombre hexadécimal en binaire et compte le nombre total de bits à 1 dans le résultat binaire.

Solution Attendue :

// Hexadécimal : 2F3
// Binaire : 0010 1111 0011
// Nombre de bits à 1 : 7
Exercice 4 : Conversion de Séquences Hexadécimales

Question : Écrire un programme en C qui lit une série de nombres hexadécimaux séparés par des virgules, les convertit en binaire, et affiche chaque conversion.

Solution Attendue :

// Entrée : 1A3,4F2,B3
// Sortie : 
// 1A3 -> 0001 1010 0011
// 4F2 -> 0100 1111 0010
// B3 -> 1011 0011
Exercice 5 : Conversion et Représentation Visuelle

Question : Écrire un programme en C qui convertit un nombre hexadécimal en binaire et affiche le résultat sous forme d’un tableau de bits. Utilisez des * pour représenter les bits à 1 et des . pour les bits à 0.

Solution Attendue :

// Hexadécimal : 9F
// Binaire : 1001 1111
// Tableau : 
// * . . .
// * * * *
// * . . .
Exercice 6 : Conversion et Opérations Bit à Bit

Question : Écrire un programme en C qui convertit deux nombres hexadécimaux en binaire, effectue une opération ET logique bit à bit entre les deux résultats binaires, et affiche le résultat de cette opération en binaire.

Solution Attendue :

// Hexadécimal 1 : A3 (1010 0011)
// Hexadécimal 2 : 5F (0101 1111)
// Résultat AND : 0000 0011
Exercice 7 : Conversion Inverse et Vérification

Question : Écrire un programme en C qui convertit un nombre hexadécimal en binaire, puis reconvertit ce nombre binaire en hexadécimal pour vérifier l’exactitude de la conversion initiale.

Solution Attendue :

// Hexadécimal : 4C
// Binaire : 0100 1100
// Hexadécimal reconverti : 4C
// Vérification : Réussi
Exercice 8 : Conversion et Opérations de Décalage

Question : Écrire un programme en C qui convertit un nombre hexadécimal en binaire, effectue un décalage logique vers la gauche de deux bits sur le résultat binaire, et affiche le nouveau résultat en binaire.

Solution Attendue :

// Hexadécimal : 3A (0011 1010)
// Binaire décalé : 1110 1000
Conclusion

Ces exercices avancés couvrent divers aspects de la conversion des nombres hexadécimaux en binaire en langage C, incluant la validation des entrées, les opérations bit à bit, et la vérification des conversions. En travaillant sur ces exercices, vous pourrez renforcer votre compréhension et votre maîtrise de ce concept clé en programmation.

Cas Particuliers et Questions Piège de Conversion Hexadécimale en Binaire en Langage C

La conversion de nombres hexadécimaux en binaire peut sembler directe, mais il existe des cas particuliers et des pièges courants qui peuvent compliquer la tâche. Voici une série de cas particuliers et de questions piège pour tester et renforcer votre compréhension.

Cas Particuliers

Nombres Hexadécimaux avec des Zéros Initiaux

  • Question : Convertir 004F en binaire.
  • Solution Attendue : 004F en hexadécimal est 0000 0000 0100 1111 en binaire.

Lettres Minuscules dans les Nombres Hexadécimaux

  • Question : Convertir aBcD en binaire.
  • Solution Attendue : aBcD en hexadécimal est 1010 1011 1100 1101 en binaire.

Nombres Hexadécimaux Composés Uniquement de Lettres

  • Question : Convertir ABCD en binaire.
  • Solution Attendue : ABCD en hexadécimal est 1010 1011 1100 1101 en binaire.

Nombres Hexadécimaux Très Longs

  • Question : Convertir 123456789ABCDEF en binaire.
  • Solution Attendue : 123456789ABCDEF en hexadécimal est 0001 0010 0011 0100 0101 0110 0111 1000 1001 1010 1011 1100 1101 1110 1111 en binaire.
Questions Piège

Validation des Entrées Hexadécimales

  • Question : Convertir G4H2 en binaire.
  • Piège : G et H ne sont pas des caractères hexadécimaux valides.
  • Solution Attendue : Le programme doit afficher une erreur pour les caractères invalides.

Combinaison de Zéros et de Lettres

  • Question : Convertir 00AB en binaire.
  • Piège : Ne pas ignorer les zéros initiaux.
  • Solution Attendue : 00AB en hexadécimal est 0000 0000 1010 1011 en binaire.

Nombres Hexadécimaux avec des Espaces

  • Question : Convertir 1 2 3 en binaire.
  • Piège : Les espaces doivent être ignorés ou considérés comme des séparateurs incorrects.
  • Solution Attendue : Le programme doit afficher une erreur ou supprimer les espaces avant la conversion.

Caractères Mixtes et Non-Hexadécimaux

  • Question : Convertir 12G3H4 en binaire.
  • Piège : Mélange de caractères hexadécimaux et non-hexadécimaux.
  • Solution Attendue : Le programme doit afficher une erreur pour les caractères G et H.

Conversion de Chaînes Vidées

  • Question : Convertir une chaîne vide en binaire.
  • Piège : Gérer les entrées vides.
  • Solution Attendue : Le programme doit afficher une erreur ou un message indiquant que l’entrée est vide.

Nombres Hexadécimaux avec des Caractères Spéciaux

  • Question : Convertir 1A#C en binaire.
  • Piège : Les caractères spéciaux comme # ne sont pas valides.
  • Solution Attendue : Le programme doit afficher une erreur pour le caractère #.

Conversion de Nombres Négatifs (Invalide en Hexadécimal)

  • Question : Convertir -2A3 en binaire.
  • Piège : Les nombres négatifs ne sont pas valides en notation hexadécimale classique.
  • Solution Attendue : Le programme doit afficher une erreur pour le signe -.
Programme de Démonstration en C pour Gérer les Cas Particuliers

Voici un programme en C qui prend en compte certains de ces cas particuliers et pièges.

#include <stdio.h>
#include <string.h>
#include <ctype.h>

void hexToBinary(char hex[]) {
    int i = 0;
    printf("Binaire: ");
    while (hex[i]) {
        if (!isxdigit(hex[i])) {
            printf("\nErreur: Caractère hexadécimal invalide %c\n", hex[i]);
            return;
        }
        switch (toupper(hex[i])) {
            case '0': printf("0000 "); break;
            case '1': printf("0001 "); break;
            case '2': printf("0010 "); break;
            case '3': printf("0011 "); break;
            case '4': printf("0100 "); break;
            case '5': printf("0101 "); break;
            case '6': printf("0110 "); break;
            case '7': printf("0111 "); break;
            case '8': printf("1000 "); break;
            case '9': printf("1001 "); break;
            case 'A': printf("1010 "); break;
            case 'B': printf("1011 "); break;
            case 'C': printf("1100 "); break;
            case 'D': printf("1101 "); break;
            case 'E': printf("1110 "); break;
            case 'F': printf("1111 "); break;
        }
        i++;
    }
    printf("\n");
}

int main() {
    char hex[100];
    printf("Entrer un nombre hexadécimal: ");
    scanf("%s", hex);
    hexToBinary(hex);
    return 0;
}

Ce programme vérifie chaque caractère pour s’assurer qu’il est bien un caractère hexadécimal valide avant de procéder à la conversion. Il affiche un message d’erreur si un caractère invalide est détecté.

En pratiquant ces cas particuliers et en prenant en compte les pièges potentiels, vous serez mieux préparé à gérer les complexités de la conversion des nombres hexadécimaux en binaire en langage C.

Autres articles

Guide : Comment créer un QCM en...
Le QCM en langage C peut être simulé dans un...
Read more
Tableaux en Langage C : Exercices Corrigés
Voici une série d'exercices corrigés sur les tableaux en langage...
Read more
Comment fonctionne la récursion terminale en C...
La récursion terminale en CLa récursion terminale est une forme...
Read more

Laisser un commentaire

Votre adresse e-mail ne sera pas publiée. Les champs obligatoires sont indiqués avec *