AlgoC

Sujets de travaux pratiques d'Algorithmes et C appliqués aux Systèmes Numériques

View on GitHub

Année: 2023-2024

Travaux pratiques 3

Objectifs

Exercice 3.1 [★]

Comprendre la taille des types de données

Écrivez un programme nommé sizeof.c pour comprendre la taille des différents types de données en C sur une machine 64 bits avec un système d’exploitation 64 bits. Le programme utilisera l’opérateur sizeof pour déterminer la taille en octets de différents types de données.

Exemple: Si vous exécutez le programme, il devrait afficher les tailles en octets de ces types de données sur votre machine 64 bits. Les valeurs exactes peuvent varier en fonction de votre système, mais voici un exemple hypothétique :

La taille de int est : 4 octets
La taille de int* est : 8 octets
La taille de int** est : 8 octets
La taille de char* est : 8 octets
La taille de char** est : 8 octets
La taille de char*** est : 8 octets
La taille de float* est : 8 octets
La taille de float** est : 8 octets
La taille de float*** est : 8 octets

Remarque: Les tailles réelles peuvent varier en fonction de la machine et du compilateur utilisés.

Exercice 3.2 [★]

Trouver le numéro le plus grand et le plus petit dans un tableau

Écrivez un programme en C nommé grand_petit.c qui crée un tableau de 100 entiers et calcule à la fois le numéro le plus grand et le numéro le plus petit dans ce tableau. Le programme doit générer des valeurs aléatoires pour remplir le tableau.

Instructions:

Exemple: Si le tableau généré contient les valeurs [534, 209, 756, 92, 387, 650, 124, 978, 315, 48, …], alors le programme devrait afficher :

Le numéro le plus grand est : 978
Le numéro le plus petit est : 48

Exercice 3.3 [★★]

Tri croissant d’un tableau

Écrivez un programme nommé tri.c qui crée un tableau de 100 entiers, puis trie ces entiers par ordre croissant. Vous pouvez utiliser l’algorithme de tri de votre choix, par exemple, le tri à bulles, le tri par insertion, ou le tri rapide (quicksort). Assurez-vous que le tableau est correctement trié à la fin de l’exécution du programme.

Exemple: Voici un exemple hypothétique de la sortie attendue :

Tableau non trié :
-2 9 1 5 8 7 3 6 4 ... (100 entiers au total)

Tableau trié par ordre croissant :
-2 3 4 5 5 6 7 8 9 ... (100 entiers au total)

Le programme devrait afficher le tableau initial non trié, puis le tableau trié par ordre croissant. Assurez-vous d’inclure la logique de tri dans votre code.

Exercice 3.4 [★★]

Recherche d’un entier dans un tableau

Écrivez un programme en C nommé chercher.c qui crée un tableau de 100 entiers, puis recherche un entier spécifique dans ce tableau. Si l’entier est présent dans le tableau, affichez le message ‘entier présent’. Sinon, affichez ‘entier absent’.

Exemple: Voici un exemple hypothétique de la sortie attendue :

Tableau :
-2 9 1 5 8 7 3 6 4 ... (100 entiers au total)

Entrez l'entier que vous souhaitez chercher : 7

Résultat : entier présent

Le programme devrait d’abord afficher le tableau initial, puis demander à l’utilisateur d’entrer l’entier qu’il souhaite chercher. Ensuite, il devrait afficher si l’entier est présent ou absent dans le tableau.

Assurez-vous d’inclure la logique de recherche dans votre code pour déterminer si l’entier est présent ou non.

Exercice 3.5 [★★]

Recherche dichotomique dans un tableau trié

Référence: Recherche Dichotomique

Écrivez un programme en C nommé recherche_dichotomique.c qui crée un tableau de 100 entiers triés par ordre croissant. Ensuite, utilisez l’algorithme de recherche dichotomique pour rechercher un entier spécifique dans ce tableau. Si l’entier est présent dans le tableau, affichez le message ‘entier présent’. Sinon, affichez ‘entier absent’.

Exemple: Voici un exemple hypothétique de la sortie attendue :

Tableau trié :
-2 3 4 5 6 7 8 9 10 ... (100 entiers au total)

Entrez l'entier que vous souhaitez chercher : 5

Résultat : entier présent

Le programme devrait d’abord afficher le tableau trié, puis demander à l’utilisateur d’entrer l’entier qu’il souhaite chercher. Ensuite, il devrait utiliser l’algorithme de recherche dichotomique pour déterminer si l’entier est présent ou absent dans le tableau trié.

Assurez-vous d’inclure l’implémentation de l’algorithme de recherche dichotomique dans votre code pour effectuer la recherche efficacement.

Exercice 3.6 [★★]

Affichage des octets de différents types de données

Écrivez un programme en C nommé octets.c qui utilise les opérateurs de pointeurs pour afficher les octets individuels de différentes variables de types de données, y compris short, int, long int, float, double et long double. L’objectif est de visualiser la représentation mémoire de ces types de données en octets.

Exemple: La sortie du programme pourrait ressembler à ceci :

Octets de short :
 02 03

Octets de int :
 01 02 03 04

Octets de long int :
 01 02 03 04 05 06 07 08 

Octets de float :
 00 a0 40 11

Octets de double :
 00 00 00 00 00 00 f0 3f

Octets de long double :
 00 00 00 00 00 00 00 00 00 00 f0 7f

Le programme doit afficher les octets de chaque type de donnée sous forme de valeurs hexadécimales. Il devrait afficher l’ordre des octets dans la mémoire en fonction de l’architecture de la machine (petit-boutiste ou gros-boutiste). Assurez-vous d’utiliser les opérateurs de pointeurs pour accéder aux octets individuels de chaque variable.

Vous devrez déclarer des variables de chaque type, obtenir leurs adresses et afficher les octets correspondants.

Exercice 3.7 [★★★]

Compter les couleurs distinctes dans un tableau

Écrivez un programme en C nommé couleur_compteur.c qui stocke 100 couleurs dans un tableau et affiche les couleurs distinctes avec leur nombre d’occurrences dans le tableau. Une couleur est représentée par quatre valeurs : R (rouge), G (vert), B (bleu) et A (alpha), chacune étant un octet.

Exemple: Supposons que le tableau contienne les couleurs suivantes :

ff 0x23 0x23 0x45
ff 0x00 0x23 0x12
ff 0x23 0x23 0x45

Le programme doit afficher :

ff 0x23 0x23 0x45 : 2
ff 0x00 0x23 0x12 : 1

Le programme doit suivre ces étapes principales :

Pour cela, vous pouvez créer une nouvelle structure pour stocker les couleurs distinctes et leur nombre d’occurrences. Parcourez le tableau de couleurs, vérifiez si une couleur existe déjà dans la structure de couleurs distinctes, et mettez à jour le compteur approprié.

Le résultat final doit être l’affichage des couleurs distinctes et de leur nombre d’occurrences dans le tableau initial de couleurs.

Exercice 3.8 [★★★]

Rechercher une phrase dans un tableau de phrases

Écrivez un programme en C nommé chercher2.c qui contient un tableau de 10 phrases (tableau de tableaux de caractères) et qui recherche si une phrase donnée est présente dans le tableau. L’objectif est de réaliser cette recherche sans utiliser les fonctions de bibliothèques standards ou externes.

Exemple: Supposons que le tableau contienne les phrases suivantes :

 "Bonjour, comment ça va ?"
 "Le temps est magnifique aujourd'hui."
 "C'est une belle journée."
 "La programmation en C est amusante."
 "Les tableaux en C sont puissants."
 "Les pointeurs en C peuvent être déroutants."
 "Il fait beau dehors."
 "La recherche dans un tableau est intéressante."
 "Les structures de données sont importantes."
 "Programmer en C, c'est génial."

Si on recherche la phrase “La programmation en C est amusante.”, le programme doit afficher “Phrase trouvée”. Si on recherche “Je préfère le Python.”, le programme doit afficher “Phrase non trouvée”.

Instructions:

Le programme doit effectuer cette recherche sans utiliser de fonctions de bibliothèques standards ou externes pour la comparaison de chaînes de caractères. Il doit se baser sur la comparaison de caractères individuels pour déterminer si une phrase est présente dans le tableau ou non.

Fichiers

chercher.c, chercher2.c, couleur_compteur.c, couleurs.c, grand_petit.c, octets.c, recherche_dichotomique.c, sizeof.c, tri.c

Instructions