wiki:2011CaoTme3

Conteneurs & Itérateurs

Au cours de ce TME nous allons passer en revue trois principaux types de conteneurs de la STL, vector<>, list<> et map<>, ainsi que leurs itérateurs. Nous verrons aussi leurs relations avec les fonction de tri.

Pour pouvoir travailler, nous allons utiliser les mots d'un petit texte fourni dans le fichier GPL_2_text.h. Le texte vous est fourni sous forme d'un tableau de char*. La fin du tableau est indiquée par un pointeur NULL.

const char* GPL_2_text[] = {
  "GNU", "GENERAL", "PUBLIC", "LICENSE",
  // ...
  NULL
  };

Le conteneur vector<>

Question 1

Écrire une fonction vectorBench1() effectuant les tâches suivantes:

  • Charger dans un vecteur de string le texte en insérant les nouveaux éléments à la fin.
  • Afficher le nombre d'éléments du vecteur.
  • Trier les éléments du vecteur.
  • Afficher tous les éléments du vecteur. On les affichera sur une seule ligne (ce sera très long).

Compiler et éxécuter ce programme. Mesurer sont temps d'exécution grâce à la commande time (si votre programme s'appelle containers).

> time ./containers

Remarque: Le temps peut varier légèrement d'une exécution à l'autre en fonction de la charge de la machine. Lancez votre programme plusieur fois pour avoir un ordre de grandeur.

Question 2

Écrire une fonction vectorBench2() idendique à la précédente, mais qui, au lieu d'insérer les éléments en fin de conteneur, les insère en tête. Sachant que vector<> n'a pas de push_front(), comment peut-on faire (simplement).

Mesurer le temps. Conclusion?

Question 3

Écrire une fonction vectorBench3(), qui effectue les mêmes traitements que vectorBench1() à ceci près que le tri, au lieu d'être effectué une seule fois en fin de fonction sera fait après l'insertion de chaque élément.

Mesurer le temps. Conclusion?

Le conteneur list<>

Question 4

On reprend les fonctions de test des vector<> et on les adapte pour la list (cela donnera les fonctions listBenchX()).

Mesurer les temps. Effectuer une comparaison entre les différents test de list<> et une comparaison entre les test identiques pour list<> et vector<>. Conclusions.

Le conteneur map<>

Question 5

Nous allons utiliser la map<> pour compter le nombre de fois qu'un mot apparaît dans le texte. La map<> aura donc pour clé un mot (i.e. une string) et pour valeur un compteur (i.e. un int.

La fonction effectuera les traitements suivants:

  • Pour chaque mot de texte:
    • Chercher si un élément ayant pour clé le mot existe.
    • S'il existe, incrémenter le compteur associé.
    • S'il n'existe pas, insérer un nouvel élément dans la map<> (une pair (clé,valeur) ) avec le compteur à 1.
  • Afficher le nombre d'éléments dans la map<>.
  • Afficher l'ensemble des éléments de la map<> sous forme d'une seule grande ligne de mot::compte.
  • Recalculer le nombre de mot du texte.

Fonction de Tri, Objet Fonctionnel

Question 6

Créer un objet fonctionnel CompareString effectuant la comparaison lexicographique inverse sur deux string. Utiliser cet objet fonctionnel en tant que trosième paramètre de la map<> et observer le résultat à l'exécution.

Last modified 14 years ago Last modified on Mar 3, 2011, 10:43:41 PM

Attachments (1)

Download all attachments as: .zip