当前位置: 首页 > article >正文

数据结构(初阶)(六)----队列

队列

  • 队列
    • 概念与结构
    • 队列的实现
      • 头文件`Queue.h`
      • 实现`Queue.c`
        • 队列与结点结构
        • 打印
        • 初始化
        • 销毁
        • 入队
        • 队列判空
        • 出队
        • 取队头元素
        • 取队尾元素
        • 队列有效数据个数
      • 测试文件`test.c`

概念与结构

概念:只允许在⼀端进⾏插⼊数据操作,在另⼀端进⾏删除数据操作的特殊线性表,队列具有先进先出FIFO(First In First Out) 的原则。

⼊队列:进⾏插⼊操作的⼀端称为队尾

出队列:进⾏删除操作的⼀端称为队头

队列底层结构选型

队列也可以数组和链表的结构实现,使⽤链表的结构实现更优⼀些,因为如果使⽤数组的结构,出队列在数组头上出数据,效率会⽐较低。

队列的实现

头文件Queue.h

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

//队列结点结构
typedef int QDataType;
typedef struct QueueNode
{
	QDataType data;
	struct QueueNode* next;
}QueueNode;

//队列结构
typedef struct Queue
{
	QueueNode* phead;	//队头
	QueueNode* ptail;	//队尾
	int size;			//记录有效数据个数
}Queue;
//打印队列
void QueuePrint(Queue* pq);
//初始化
void QueueInit(Queue* pq);
//销毁
void QueueDestory(Queue* pq);
//入队
void QueuePush(Queue* pq, QDataType x);
//队列判空
bool QueueEmpty(Queue* pq);
//出队
void QueuePop(Queue* pq);
//取队头元素
QDataType QueueFront(Queue* pq);
//取队尾元素
QDataType QueueBack(Queue* pq);
//队列有效数据个数
int QueueSize(Queue* pq);

实现Queue.c

队列与结点结构
//队列结点结构
typedef int QDataType;
typedef struct QueueNode
{
	QDataType data;
	struct QueueNode* next;
}QueueNode;

//队列结构
typedef struct Queue
{
	QueueNode* phead;	//队头
	QueueNode* ptail;	//队尾
	int size;			//记录有效数据个数
}Queue;
打印
//打印队列
void QueuePrint(Queue* pq)
{
	assert(pq);
	QueueNode* pcur = pq->phead;
	while (pcur)
	{
		printf("%d ", pcur->data);
		pcur = pcur->next;
	}
	printf("\n");
}
初始化
//初始化
void QueueInit(Queue* pq)
{
	assert(pq);
	pq->phead = pq->ptail = NULL;
	pq->size = 0;
}
销毁
//销毁
void QueueDestory(Queue* pq)
{
	assert(pq);	
	QueueNode* pcur = pq->phead;
	while (pcur)
	{
		QueueNode* next = pcur->next;
		free(pcur);
		pcur = next;
	}
	pq->phead = pq->ptail = NULL;
}
入队
//入队
void QueuePush(Queue* pq, QDataType x)
{
	assert(pq);
	QueueNode* newNode = (QueueNode*)malloc(sizeof(QueueNode));
	if (newNode == NULL)
	{
		perror("malloc fail");
		exit(1);
	}
	newNode->data = 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;
}
队列判空
//队列判空
bool QueueEmpty(Queue* pq)
{
	assert(pq);
	return pq->phead == 0;
}
出队
//出队
void QueuePop(Queue* pq)
{
	assert(!QueueEmpty(pq));
	//出队的是头结点
	//当队列中只有一个结点时
	if (pq->phead == pq->ptail)
	{
		free(pq->phead);
		pq->phead = pq->ptail = NULL;
	}else {
		QueueNode* next = pq->phead->next;
		free(pq->phead);
		pq->phead = next;
	}
	--pq->size;
}
取队头元素
//取队头元素
QDataType QueueFront(Queue* pq)
{
	assert(pq);
	return pq->phead->data;
}
取队尾元素
//取队尾元素
QDataType QueueBack(Queue* pq)
{
	assert(pq);
	return pq->ptail->data;
}
队列有效数据个数

可以选择遍历队列,但是使用size次数较多,循环遍历,额外浪费时间
也可以在定义队列结构时,加上int size作为计数器

//队列有效数据个数
//int QueueSize(Queue* pq)
//{
//	int size = 0;
//	QueueNode* pcur = pq->phead;
//	while (pcur)
//	{
//		++size;
//		pcur = pcur->next;
//	}
//	return size;
//}
int QueueSize(Queue* pq)
{
	return pq->size;
}

测试文件test.c

#define _CRT_SECURE_NO_WARNINGS
#include"Queue.h"

void test1()
{
	Queue q;
	//初始化
	QueueInit(&q);
	//入队
	QueuePush(&q,1);
	QueuePush(&q,2);
	QueuePush(&q,3);
	QueuePush(&q,4);

	//打印队列
	QueuePrint(&q);

	出队
	//QueuePop(&q);
	//QueuePop(&q);
	//QueuePop(&q);

	//取队头元素
	QDataType head = QueueFront(&q);
	printf("队头元素:%d\n", head);
	
	//取队头元素
	QDataType tail = QueueBack(&q);
	printf("队尾元素:%d\n", tail);
	
	//队列有效数据个数
	int size = QueueSize(&q);
	printf("有效数据个数:%d\n", size);

	//销毁
	QueueDestory(&q);
}

int main()
{
	test1();
	return 0;
}

http://www.kler.cn/a/569812.html

相关文章:

  • ctfshow刷题笔记—栈溢出—pwn61~pwn64
  • C++类和对象:匿名对象及连续构造拷贝编译器的优化
  • Vscode通过Roo Cline接入Deepseek
  • 授权与认证之jwt(三)刷新令牌该如何设计
  • 计算机网络学习————(五)TCP/IP学习
  • ubuntu Linux 正确设置中文环境的方法
  • Python常见面试题的详解24
  • 实现用户特征自动识别和动态圈子创建,需构建一套完整的自动化流程
  • 本地搭建Ollama运行各种平台的大模型(deepseek),配合AnythingLLM-UI界面使用
  • 2025-02-28 学习记录--C/C++-PTA 7-34 通讯录的录入与显示
  • 基于消息事件实现结合状态机实现事件触发通用单片机逻裸机框架处理
  • 《机器学习数学基础》补充资料:线性变换和最小二乘
  • 【Go语言快速上手】第一部分:数据类型(数组、切片、映射)与控制语句
  • 【JAVA-数据结构】枚举
  • Storm实时流式计算系统(全解)——中
  • TCP的三次握⼿中为什么是三次?为什么不是两 次、四次?
  • 数据可视化02-PCA降维
  • 【推荐项目】023-游泳俱乐部管理系统
  • 解决Java项目中Maven爆红,三方包下载不下来的问题
  • 基于单片机和C#的电压监测系统设计