1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81
|
#include <stdlib.h>
#include <stdio.h>
#include <string.h>
typedef struct node
{
void *Ptr_val; /* pointeur sur un type de valeur desire */
struct node *Suiv; /* pointeur sur element suivant */
}
node_s;
typedef struct
{
node_s *head;
node_s *tail;
}
list_s;
/* ajoute un pointeur sur valeur en fin de liste*/
int Ajouter_fin (list_s * L, void *Ptr_valeur)
{
int err = 1;
node_s *new = malloc (sizeof *new);
if (new != NULL)
{
new->Ptr_val = Ptr_valeur; /* pointer valeur */
new->Suiv = NULL; /* fin de liste */
if (L->head == NULL) /* si liste vide */
{
L->head = new;
}
else
{
L->tail->Suiv = new;
}
L->tail = new;
err = 0;
}
return err;
}
void aff (list_s * L)
{
node_s *p = L->head;
if (p != NULL)
{
do
{
printf ("'%s'\n", (char *) p->Ptr_val);
p = p->Suiv;
}
while (p != NULL);
}
else
{
puts ("VIDE");
}
}
int main (void)
{
list_s list = { NULL, NULL };
int err;
err = Ajouter_fin (&list, strdup ("Hello"));
if (!err)
{
err = Ajouter_fin (&list, strdup ("World"));
if (!err)
{
aff (&list);
}
}
return 0;
} |