TD-5, encore les pointeurs |
On se propose de réaliser une petite calculette HP.
Cette première partie s’inspire du cours. On utilisera une pile stack, globale et codée en machine par une liste d’entiers, voici la définition de stack et le constructeur des listes :
typedef struct cell {
int val;
struct cell *next;
} Cell, *Stack;
Stack stack = NULL;
Cell *cons(int val,Cell *next)
{
Cell *r;
r = (Cell *)malloc(sizeof(Cell));
if ( r == NULL) {
fprintf(stderr,"Plus de memoire\n");
exit(-1);
}
r->val = val;
r->next = next;
return r;
}
void afficher(void)
int pop(void)
void push(int i)
La calculatrice obéira à un programme contenu dans une chaîne de
caractères et affichera, à chaque étape intermédiaire, le caractère lu
(utiliser printf
avec le format "%c"
)
et l’état de de la pile. Par exemple,
pour le programme "12-34++", on aura (la pile est affichée du
sommet vers le fond) :
[]
1 : [1]
2 : [2, 1]
- : [-1]
3 : [3, -1]
4 : [4, 3, -1]
+ : [7, -1]
+ : [6]
Vous aurez donc à lire la chaîne-programme caractère par caractère (rappelez vous qu’une chaîne est un tableau de caractères) et à empiler un entier ou à réaliser une opération selon ce que vous avez lu. Les quatre opérations devront bien entendu utiliser les primitives de pile, push et pop. Attention au sens de la soustraction et de la division.
Les vraies calculatrices HP ont des touches spéciales qui permettent des manipulations de la pile. Les opérations suivantes (qui diffèrent un peu de celles des calculatrices HP) sont à réaliser sans allouer aucune cellule de liste.
[]
1 : [1]
2 : [2, 1]
s : [1, 2]
- : [1]
[]
4 : [4]
3 : [3, 4]
2 : [2, 3, 4]
1 : [1, 2, 3, 4]
u : [2, 3, 4, 1]
[]
4 : [4]
3 : [3, 4]
2 : [2, 3, 4]
1 : [1, 2, 3, 4]
d : [4, 1, 2, 3]
Remarquez que les rotations reviennent, pour la rotation vers le haut, à mettre la cellule de tête en queue de liste et pour la rotation vers le bas, à mettre la cellule de queue en tête de liste. Vous aurez sans doute intérêt à faire de petits dessins pour vous guider.
La solution de cet exercice apparaîtra en hp.c.
Réaliser une calculatrice PH, dont la structure de contrôle est une file. La file sera réalisée par une liste (voir la fin du cours). Une opération se fera en défilant les deux arguments et en enfilant le résultat. Vous pouvez aller jusqu’à donner une signification claire aux rotations et à les programmer.
Ce document a été traduit de LATEX par HEVEA