【数据结构——队列的实现(单链表)】

数据结构------队列的实现(单链表)

一.队列

1.1队列的概念及结构

二.队列的实现

2.1 头文件的实现------(Queue.h)

c 复制代码
Queue.h
c 复制代码
#pragma once


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

typedef int QDataType;
typedef struct QueueNode
{
	QDataType val;
	struct QueueNode* next;
}QNode;


typedef struct Queue
{
	QNode* phead;
	QNode* ptail;
	int size;
}Queue;

//初始化/销毁
void QueueInit(Queue* pq);
void QueueDestroy(Queue* pq);

//出队/入队
void QueuePush(Queue* pq, QDataType x);
void QueuePop(Queue* pq);
//获取队头元素/队尾元素
QDataType QueueFront(Queue* pq);
QDataType QueueBack(Queue* pq);
//判空/统计队列元素个数
bool QueueEmpty(Queue* pq);
int QueueSize(Queue* pq);

2.2 源文件的实现------ (Queue.c)

c 复制代码
Queue.c
c 复制代码
#include"Queue.h"


//初始化/销毁
void QueueInit(Queue* pq)
{
	assert(pq);
	pq->phead = pq->ptail = NULL;
	pq->size = 0;
}
void QueueDestroy(Queue* pq)
{
	assert(pq);
	QNode* cur = pq->phead;
	while (cur)
	{
		QNode* Next = cur->next;
		free(cur);
		cur = Next;
	}
	pq->phead = pq->ptail = NULL;
	pq->size = 0;
}

//队尾入队/队首出队
void QueuePush(Queue* pq, QDataType x)
{
	assert(pq);
	QNode* Newnode = (QNode*)malloc(sizeof(QNode));
	if (Newnode == NULL)
	{
		perror("malloc fail");
		return;
	}
	Newnode->val = x;
	Newnode->next = NULL;
	if (pq->phead == NULL)
	{
		pq->phead = pq->ptail = Newnode;
	}
	else
	{
		pq->ptail->next = Newnode;
		pq->ptail = pq->ptail->next;
	}
	pq->size++;
}
void QueuePop(Queue* pq)
{
	assert(pq);
	assert(pq->phead);
	QNode* del = pq->phead;
	pq->phead = pq->phead->next;
	free(del);
	del = NULL;

	if (pq->phead == NULL)
		pq->ptail = NULL;
	pq->size--;


}

//获取队头元素/队尾元素
QDataType QueueFront(Queue* pq)
{
	assert(pq);
	assert(pq->phead);

	return pq->phead->val;
}
QDataType QueueBack(Queue* pq)
{
	assert(pq);
	assert(pq->ptail);

	return pq->ptail->val;

}
//判空/统计队列元素个数
bool QueueEmpty(Queue* pq)
{
	assert(pq);
	return pq->phead == NULL;
}
int QueueSize(Queue* pq)
{
	assert(pq);

	return pq->size;
}

2.3 源文件的实现------ (test.c)

c 复制代码
test.c
c 复制代码
#include"Queue.h"


int main()
{
	Queue S;
	QueueInit(&S);
	QueuePush(&S, 1);
	QueuePush(&S, 2);
	printf("%d ", QueueFront(&S));
	QueuePop(&S);
	QueuePush(&S, 3);
	QueuePush(&S, 4);
	printf("%d ", QueueFront(&S));
	QueuePop(&S);
	QueuePush(&S, 5);

	while (!QueueEmpty(&S))
	{
		printf("%d ", QueueFront(&S));
		QueuePop(&S);
	}
	QueueDestroy(&S);
}

三.队列的实际数据测试展示

1.出入队列的方式:队尾进入,对首出队列。
2.出队列和入队列的关系是:一对一的。

3.1正常出队列入队列

3.2 入队列的同时存在出队列

相关推荐
HZ·湘怡38 分钟前
二叉树 2 堆
算法
wabs6668 小时前
关于贪心算法的思考
算法·贪心算法
社交怪人8 小时前
【判断大小】信息学奥赛一本通C语言解法(题号1043)
算法
Snasph8 小时前
GNU Make 用户手册(中文版)
服务器·算法·gnu
江澎涌9 小时前
拆解与 AI 的一次对话
人工智能·算法·程序员
sheeta19989 小时前
LeetCode 每日一题笔记 日期:2026.06.02 题目:3635. 最早完成陆地和水上游乐设施的时间 II
笔记·算法·leetcode
Lsk_Smion9 小时前
力扣实训 _ [102].层序遍历--前序--后续_递归与非递归的实现
数据结构·算法·leetcode
Lsk_Smion10 小时前
力扣实训 _ [25].K个一组链表
数据结构·链表
小欣加油11 小时前
leetcode3751 范围内总波动值I
java·数据结构·c++·算法·leetcode
玖玥拾11 小时前
C/C++ 基础笔记(七)
c语言·c++