-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathqueue-using-sll.c
More file actions
executable file
·111 lines (101 loc) · 1.85 KB
/
queue-using-sll.c
File metadata and controls
executable file
·111 lines (101 loc) · 1.85 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
#include <stdio.h>
#include <stdlib.h>
#define MAKS 5
typedef struct Queue queue;
typedef char dataType;
struct Queue
{
dataType data;
queue *next;
};
void tampil();
void alokasi();
void insert_akhir();
void delete_awal();
void free_node(queue *);
queue *p=NULL, *datax=NULL, *rear=NULL, *front=NULL;
int main()
{
printf("Menu Queue\n");
printf("1. Isi Queue (Enqueue)\n");
printf("2. Baca Queue (Dequeue)\n");
printf("3. Tampilkan Queue (LIFO)\n\n");
int menu;
do
{
printf("Masukkan menu: ");
scanf(" %d", &menu);
fflush(stdin);
switch(menu)
{
case 1: insert_akhir(); break;
case 2: delete_awal(); break;
case 3: tampil(); break;
case 4: printf("Bye!!\n"); exit(0); break;
default: printf("Menu salah!\n");
}
} while(menu != 4);
return 0;
}
void alokasi()
{
p=(queue *)malloc(sizeof(queue));
if(p==NULL)
printf("Malloc error\n");
else
{
printf("Masukkan data: ");
scanf(" %c", &p->data);
p->next=NULL;
}
}
void insert_akhir()
{
alokasi();
if(datax==NULL)
{
datax=p;
rear=datax;
}
else
{
rear->next=p;
rear=p;
}
}
void delete_awal()
{
if(datax==NULL)
printf("Queue kosong!\n");
else
{
printf("%c\n", datax->data);
front=datax;
if(datax->next==NULL)
datax=NULL;
else
datax=datax->next;
free_node(front);
}
}
void free_node(queue *q)
{
free(q);
q=NULL;
}
void tampil()
{
queue *baca;
baca=datax;
if(datax==NULL)
printf("Queue kosong!\n");
else
{
while(baca!=NULL)
{
printf("%c->", baca->data);
baca=baca->next;
}
printf("\b\b\n");
}
}