-
Notifications
You must be signed in to change notification settings - Fork 18
/
Copy path04-鍵結串列實作佇列.c
99 lines (86 loc) · 2.32 KB
/
04-鍵結串列實作佇列.c
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
#include <stdio.h>
#include <stdlib.h>
struct e {
char* name;
int length;
struct e* next;
};
typedef struct e* element;
struct q {
// o -> o -> o -> o
// ^de ^en
element en; // 指向要加入的那端
element de; // 指向要取出的那端
};
typedef struct q* queue;
void enqueue(queue* this, element e) {
// 如果該佇列為空就新增一個佇列
if (!(*this)) {
queue new = malloc(sizeof(*new));
new->en = e;
new->de = e;
*this = new;
return;
}
// 於 en 的位址加入佇列
(*this)->en->next = e;
(*this)->en = (*this)->en->next;
}
element dequeue(queue* this) {
if (*this == NULL) {
fprintf(stderr, "Queue is Empty\n");
exit(EXIT_FAILURE);
}
element tmp = (*this)->de;
(*this)->de = (*this)->de->next;
// 佇列為空時直接將其設為 NULL 方便判斷其為空佇列
if (!((*this)->de)) {
*this = NULL;
}
return tmp;
}
// 方便我們觀察 Queue 變化
void printQueueLn(queue this) {
element current;
for (current = this->de; current; current = current->next) {
printf("%s (%d s)\t", current->name, current->length);
}
printf("\n");
}
element createElement(char* name, int len) {
element e = malloc(sizeof(*e));
e->name = name;
e->length = len;
e->next = NULL;
return e;
}
int main() {
element song1 = createElement("如果我們不曾相遇", 229);
element song2 = createElement("盛夏光年", 349);
element song3 = createElement("說散就散", 219);
element song4 = createElement("金曜日のおはよう", 242);
queue q = NULL;
enqueue(&q, song1);
printQueueLn(q);
enqueue(&q, song2);
printQueueLn(q);
enqueue(&q, song3);
printQueueLn(q);
dequeue(&q);
printQueueLn(q);
dequeue(&q);
printQueueLn(q);
enqueue(&q, song4);
printQueueLn(q);
/*
這個範例用的比較偏物件導向的感覺
其是如果怕麻煩的話直接宣告一個
rear 來代替 queue->en
front 來代替 queue->de
也可以達到一樣的效果
另外在 enqueue 的部份可以改成
先 create queue 再 enqueue 會比較簡單一些些
但是我用的就是有一點點偏 oop 的風格 (?
*/
return 0;
}