【数据结构 02】队列

一、原理

队列通常是链表结构,只允许在一端进行数据插入,在另一端进行数据删除。

队列的特性是链式存储(随机增删)和先进先出(FIFO:First In First Out)。

队列的缺陷:

  1. 不支持随机访问
  2. 不支持随机增删
  3. 每个数据都需要维护一个指针,增大了空间资源消耗

二、Queue.h

cpp 复制代码
#define _CRT_SECURE_NO_WARNINGS 1

#include <stdio.h>
#include <stdlib.h>

typedef int DataType;

typedef struct Node
{
	DataType data;
	struct Node* next;
}Node;

typedef struct Queue
{
	Node* head;
	int size;
}Queue;

void Init(Queue* q)
{
	// 初始化创建一个空的头节点
	q->head = (Node*)malloc(sizeof(Node));
	q->head->next = NULL;
	q->size = 0;
}

int Empty(Queue* q)
{
	return q->size == 0;
}

void Push(Queue* q, DataType x)
{
	Node* node = (Node*)malloc(sizeof(Node));
	node->data = x;
	node->next = NULL;

	Node* cur = q->head;
	while (cur->next != NULL)
	{
		cur = cur->next;
	}

	cur->next = node;
	++q->size;
}

void Pop(Queue* q)
{
	if (Empty(q))
	{
		printf("队列为空,pop失败\n");
		return;
	}

	Node* cur = q->head->next;
	q->head->next = cur->next;
	
	free(cur);
	cur = NULL;
	--q->size;
}

DataType Front(Queue* q)
{
	if (Empty(q))
	{
		printf("队列为空,无队列首元素\n");
		return NULL;
	}

	return q->head->next->data;
}

void Destroy(Queue* q)
{
	while (!Empty(q))
	{
		Pop(q);
	}
	free(q->head);
	q->head = NULL;
	printf("队列销毁成功\n");
}

int Size(Queue* q)
{
	return q->size;
}

void Print(Queue* q)
{
	if (Empty(q))
	{
		printf("队列为空\n");
		return;
	}

	Node* cur = q->head->next;
	while (cur != NULL)
	{
		printf("%2d ", cur->data);
		cur = cur->next;
	}
	printf(",队列首元素:%2d,队列长度为:%d\n", Front(q), Size(q));
}

三、test.c

cpp 复制代码
#define _CRT_SECURE_NO_WARNINGS 1

#include "Queue.h"

int main()
{
	Queue q;
	Init(&q);
	Push(&q, 1);
	Push(&q, 3);
	Push(&q, 5);
	Push(&q, 7);
	Push(&q, 2);
	Push(&q, 4);
	Push(&q, 6);
	Push(&q, 8);
	Print(&q);

	Pop(&q);
	Pop(&q);
	Pop(&q);
	Print(&q);

	Push(&q, 9);
	Print(&q);

	Pop(&q);
	Pop(&q);
	Pop(&q);
	Pop(&q);
	Pop(&q);
	Pop(&q);
	Pop(&q);
	Pop(&q);
	Pop(&q);
	Print(&q);

	Push(&q, 10);
	Push(&q, 20);
	Print(&q);
	Destroy(&q);
	Print(&q);
}
相关推荐
ChoSeitaku38 分钟前
链表交集相关算法题|AB链表公共元素生成链表C|AB链表交集存放于A|连续子序列|相交链表求交点位置(C)
数据结构·考研·链表
偷心编程39 分钟前
双向链表专题
数据结构
香菜大丸39 分钟前
链表的归并排序
数据结构·算法·链表
jrrz082839 分钟前
LeetCode 热题100(七)【链表】(1)
数据结构·c++·算法·leetcode·链表
@小博的博客1 小时前
C++初阶学习第十弹——深入讲解vector的迭代器失效
数据结构·c++·学习
泉崎3 小时前
11.7比赛总结
数据结构·算法
你好helloworld3 小时前
滑动窗口最大值
数据结构·算法·leetcode
JSU_曾是此间年少4 小时前
数据结构——线性表与链表
数据结构·c++·算法
sjsjs114 小时前
【数据结构-合法括号字符串】【hard】【拼多多面试题】力扣32. 最长有效括号
数据结构·leetcode
blammmp5 小时前
Java:数据结构-枚举
java·开发语言·数据结构