-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathpile.c
More file actions
124 lines (97 loc) · 1.67 KB
/
pile.c
File metadata and controls
124 lines (97 loc) · 1.67 KB
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
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
// pile last in first out
#include<stdio.h>
#include<stdlib.h>
typedef struct Element
{
int val;
struct Element *next;
}Element;
typedef struct
{
Element *tete ;
Element *queue;
}pile;
// fonction init vide tete enpiler depiler afficher
// initialisation de la pile
void init(pile * p )
{
p->tete=NULL;
p->queue=NULL;
}
// verfier si elle est vide
int vide (pile p )
{
return p.tete == NULL ;
}
// retourner la valeur de la tete
int tete(pile p )
{
return p.tete->val;
}
//retourner la valeur de la queue
int queue(pile p )
{
return p.queue->val;
}
//enplier
void enpiler(pile * p,int x)
{
Element * e = (Element*)malloc(sizeof(Element));
e->val=x;
e->next=NULL;
if(vide(*p))
{p->tete=e;
p->queue=e;}
else{
p->queue->next=e;
p->queue=e;
}
}
//depiler
int depiler(pile * p)
{
int x = p->queue->val;
Element * eq = p->queue;
if (p->tete == p->queue) {
p->tete = NULL;
p->queue = NULL;
} else {
Element * et = p->tete;
while (et->next != eq) {
et = et->next;
}
p->queue = et;
p->queue->next = NULL;
}
free(eq);
return x;
}
//afficher
void afficher(pile p)
{Element * e=p.tete;
while(e!=NULL)
{printf("%d \t",e->val);
e=e->next;
}
}
void main()
{
pile p;
init(&p);
printf("vide : %d \n",vide(p));
enpiler(&p,1);
enpiler(&p,2);
enpiler(&p,3);
enpiler(&p,4);
enpiler(&p,5);
enpiler(&p,6);
printf("afficher pile aprés remplissage\n");
afficher(p);
printf("\n vide : %d \n",vide(p));
printf("\n tete : %d \n",tete(p));
printf("\nqueue : %d \n",queue(p));
printf("valeur depilée: %d \n", depiler(&p));
printf("afficher pile aprés avoir dépilé (last in first out)\n");
afficher(p);
printf("\n");
}