🧪 Labo 5.1A – Formatif
Ce laboratoire doit être développé à l'aide du logiciel Git. Vous devrez créer un nouveau dépôt dans GitHub et inviter votre professeur en tant que collaborateur.
Voici le format du dépôt exigé: H26-2P6-R09-MATRICULE
Il devrait y avoir un commit pour chaque exercice.
Télécharger la solution contenant les différents exercices de ce laboratoire.
Disponible ici 👉 Laboratoire5_1
📊 Critères d’évaluation
- Exactitude du fonctionnement La méthode produit les résultats attendus dans les cas demandés.
- Respect des validations Les validations exigées sont correctement implémentées (valeurs permises, cas limites, erreurs).
- Respect des standards de programmation Nommage clair, indentation correcte, commentaires pertinents et respect des conventions vues en classe.
- Qualité du code (lisibilité et organisation) Code bien structuré, facile à lire et à comprendre, sans duplication inutile.
🟡 Exercice A – Gestion de personnes
🎯 Objectifs
- Instanciation et utilisation d'un objet
- Manipulation des listes d'objets
- Lecture / écriture de fichiers csv
- Utilisation des énumérations
- Parcours avec
foreach - Définition de méthodes
🛠️ Instructions
Vous devez développer un ensemble de méthodes permettant de gérer une collection d’objets Personne: charger, filtrer, ajouter, supprimer et sauvegarder des données.
La classe Personne et le type par énumération TypeRecherche sont fournies. Il ne faut pas les modifier.
🧪 Directives pour utiliser les tests
- Des tests sont fournis pour vous aider à valider votre travail. ils ne sont pas exhaustifs et ne remplacent pas vos propres tests, nécessaires pour assurer que votre code est correct.
- Tous les tests sont regroupés dans un fichier séparé du programme principal (
TestsPersonne.cs). - Pour utiliser un test, vous devez d’abord définir la méthode demandée en respectant exactement sa définition (paramètres et type de retour).
- Décommentez ensuite le test correspondant.
- Démarrez l’application et observez le résultat affiché dans la console.
- ⚠️ Si le programme ne compile pas après avoir décommenté un test, cela signifie que la méthode n’est pas définie comme demandé.
Les lignes à décommenter pour activer les tests se trouvent au début du fichier (TestsPersonne.cs).
//#define TEST_EST_DANS_LA_LISTE
//#define TEST_AJOUTER_PERSONNE
//#define TEST_SUPPRIMER_PERSONNE
//#define TEST_FILTRER_AGE
//#define TEST_MOYENNE_AGE
//#define TEST_RECHERCHE
//#define TEST_SAUVEGARDER
//#define TEST_CHARGER
📊 Diagramme de classes
La classe Personne et le type par énumération TypeRecherche sont fournies. Il ne faut pas les modifier.
La classe est déjà documentée dans le code. Vous devez l'observer et la comprendre. Cette étape vous permet de savoir quelles propriétés et méthodes sont disponibles pour l’utiliser correctement dans le reste du programme.

🧩 Méthodes à implémenter
1️⃣ EstDansLaListe
On veut savoir si une personne existe déjà dans la liste à partir de son NAS.
📥 Paramètres nécessaires
- Un NAS à rechercher
- Une liste de personnes
📤 Retour attendu
- Un booléen indiquant si la personne est présente ou non
✅ Contraintes
- La comparaison doit être insensible à la casse
- Si la liste est null → retourner false
- Si le NAS est vide ou null → retourner false
2️⃣ AjouterPersonne
On veut ajouter une nouvelle personne dans la liste.