/*
链式队列(不带头结点)
*/
#include <iostream>
using namespace std;
typedef int ElemType;
// 结点
struct LinkNode {
ElemType data;
LinkNode *next;
};
// 链式队列
struct LinkQueue {
LinkNode *front, *rear; // 队头指针,队尾指针
};
// 初始化队列
void InitQueue(LinkQueue &Q) {
Q.front = NULL;
Q.rear = NULL;
}
// 队列判空
bool QueueEmpty(LinkQueue &Q) {
if (Q.front == NULL) {
return true;
} else {
return false;
}
}
// 入队
bool EnQueue(LinkQueue &Q, ElemType x) {
// LinkNode *s = (LinkNode *)malloc(sizeof(LinkNode));
LinkNode *s = new LinkNode;
if (s == NULL)
return false;
s->data = x;
s->next = NULL;
if (Q.front == NULL) {
Q.front = s;
Q.rear = s; // 队头队尾指针指向同一位置
} else {
Q.rear->next = s; // 新元素插入
Q.rear = s; // 修改表尾指针
}
return true;
}
// 出队
bool DeQuene(LinkQueue &Q, ElemType &x) {
if (Q.front == NULL) {
return false;
} else {
LinkNode *p = Q.front; // 指向头结点
x = p->data;
if (Q.rear == p) { // 队列中只有一个元素
Q.front = NULL;
Q.rear = NULL;
} else {
Q.front = p->next; // 更新队头指针
}
delete p;
return true;
}
}
// 获取队头元素
bool GetHead(LinkQueue &Q, ElemType &head) {
if (Q.front == NULL) {
return false;
} else {
head = Q.front->data;
return true;
}
}
// 获取队列长度
int GetLength(LinkQueue &Q, ElemType &len) {
if (Q.front == NULL) {
return 0;
} else {
len = 1;
LinkNode *p = Q.front; // 指向队头
while (p != Q.rear) {
p = p->next;
len++;
}
return len;
}
}
// 销毁队列
bool DestroyQueue(LinkQueue &Q, ElemType &x) {
while (!QueueEmpty(Q)) {
DeQuene(Q, x); // 如果队列不为空,则一直出队
}
return true;
}
int main() {
LinkQueue Q;
InitQueue(Q);
ElemType head, pop, length;
cout << "队列是否为空:" << QueueEmpty(Q) << endl;
for (int i = 10; i < 15; i++) {
EnQueue(Q, i);
}
cout << "队列是否为空:" << QueueEmpty(Q) << endl;
GetHead(Q, head);
cout << "队头元素:" << head << endl;
cout << "队列长度:" << GetLength(Q, length) << endl;
DeQuene(Q, pop);
cout << "出队元素:" << pop << endl;
GetHead(Q, head);
cout << "队头元素:" << head << endl;
cout << "队列长度:" << GetLength(Q, length) << endl;
DestroyQueue(Q, head);
cout << "队列是否为空:" << QueueEmpty(Q) << endl;
cout << "队列长度:" << GetLength(Q, length) << endl;
}