C语言实现队列

前言:在实现栈之后我们再介绍一下他的孪生兄弟,一个是后进先出,一个是先进先出。那么就让我们来详细的了解一下队列把。

目录

一.队列概念

二.队列的实现

1.定义队列

2.初始化队列

3.入队

4.判断队列是否为空

5.出队

6.返回队头和队尾

7.查看队尾内容

8.查看队列数量

9.销毁队列

三.队列实现所有代码

四.结言


一.队列概念

队列:

只允许在一端进行插入数据操作,在另一端进行删除数据操作的特殊线性表,队列具有先进先出

FIFO(First In First Out) 入队列:进行插入操作的一端称为队尾 出队列:进行删除操作的一端称为队头

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

在数组内实现避免不了有数据的移动,比如将a0当队头插入队列时进行尾插,但是在每次出队的时候需要将后面的数据向前移动一位,这就不免是(n-1)的时间复杂度。

而将an做位队头那么每次插入时又需要挪动数据,时间复杂度也是(n-1),所以我们采用链表的方式实现就很方便。

二.队列的实现

1.定义队列

cpp 复制代码
typedef int QEtype;

typedef struct QEnode{
	QEtype val;
	struct QEnode *next;
}QEnode;

typedef struct QE
{
	QEnode* head;
	QEnode* tail;
	int size;
}QE;

这里我们把队列的队头,队尾以及队列的长度记录下来。这样会对我们进行的操作有很大的便利。

2.初始化队列

cpp 复制代码
void QEInit(QE* qe)
{
	assert(qe);
	qe->head = NULL;
	qe->tail = NULL;
	qe->size = 0;
}

3.入队

cpp 复制代码
void QEPush(QE* qe, QEtype x)
{
	assert(qe);
	QEnode* newnext = (QEnode*)malloc(sizeof(QEnode));
	if (newnext == NULL)
	{
		perror(malloc);
		return;
	}
	newnext->next = NULL;
	newnext->val = x;
	if (qe->size == 0)
	{
		qe->head = qe->tail = newnext;
		
	}
	else
	{
		qe->tail->next = newnext;
		qe->tail = newnext;
		
	}
	qe->size++;
}

我们入队列选用的是尾插。

4.判断队列是否为空

cpp 复制代码
_Bool QEempty(QE* qe)
{
	assert(qe);
	return qe->size == 0;
}

5.出队

cpp 复制代码
void QEPop(QE* qe)
{
	assert(qe);
	assert(!QEempty(qe));
	if (qe->size == 1)
	{
		free(qe->head);
		qe->head = NULL;
		qe->tail = NULL;

	}
	else
	{
		QEnode* prev = qe->head->next;
		free(qe->head);
		qe->head = prev;
	}
	qe->size--;
}

对于出队我们选用头删。

6.返回队头和队尾

cpp 复制代码
QEnode* QETop(QE* qe)
{
	assert(qe);
	assert(!QEempty(qe));
	return qe->head;
}
QEnode* QEDown(QE* qe)
{
	assert(qe);
	assert(!QEempty(qe));
	return qe->tail;
}

这就是我们当时表示出来队头和队尾的方便之处。

7.查看队尾内容

cpp 复制代码
QEtype ShowDown(QE* qe)
{
	assert(qe);
	assert(!QEempty(qe));
	return qe->tail->val;
}

8.查看队列数量

cpp 复制代码
int QESize(QE* qe)
{
	assert(qe);
	assert(!QEempty(qe));
	return qe->size;
}

9.销毁队列

cpp 复制代码
void QEDestory(QE* qe)
{
	assert(qe);
	qe->head = qe->tail = NULL;
	qe->size = 0;
	free(qe->head);
	free(qe->tail);

}

三.队列实现所有代码

cpp 复制代码
QE.h
#pragma once
#include<stdio.h>
#include<stdlib.h>
#include<assert.h>
#include<stdbool.h>

typedef int QEtype;

typedef struct QEnode{
	QEtype val;
	struct QEnode *next;
}QEnode;

typedef struct QE
{
	QEnode* head;
	QEnode* tail;
	int size;
}QE;

void QEInit(QE* qe);
void QEPush(QE* qe, QEtype x);
void QEPop(QE* qe);
_Bool QEempty(QE* qe);
QEnode* QETop(QE* qe);
QEnode* QEDown(QE* qe);
QEtype ShowDown(QE* qe);
int QESize(QE* qe);
void QEDestory(QE* qe);


QE.c
void QEInit(QE* qe)
{
	assert(qe);
	qe->head = NULL;
	qe->tail = NULL;
	qe->size = 0;
}
void QEPush(QE* qe, QEtype x)
{
	assert(qe);
	QEnode* newnext = (QEnode*)malloc(sizeof(QEnode));
	if (newnext == NULL)
	{
		perror(malloc);
		return;
	}
	newnext->next = NULL;
	newnext->val = x;
	if (qe->size == 0)
	{
		qe->head = qe->tail = newnext;
		
	}
	else
	{
		qe->tail->next = newnext;
		qe->tail = newnext;
		
	}
	qe->size++;
}
_Bool QEempty(QE* qe)
{
	assert(qe);
	return qe->size == 0;
}
void QEPop(QE* qe)
{
	assert(qe);
	assert(!QEempty(qe));
	if (qe->size == 1)
	{
		free(qe->head);
		qe->head = NULL;
		qe->tail = NULL;

	}
	else
	{
		QEnode* prev = qe->head->next;
		free(qe->head);
		qe->head = prev;
	}
	qe->size--;
}
QEnode* QETop(QE* qe)
{
	assert(qe);
	assert(!QEempty(qe));
	return qe->head;
}
QEnode* QEDown(QE* qe)
{
	assert(qe);
	assert(!QEempty(qe));
	return qe->tail;
}
QEtype ShowDown(QE* qe)
{
	assert(qe);
	assert(!QEempty(qe));
	return qe->tail->val;
}
int QESize(QE* qe)
{
	assert(qe);
	assert(!QEempty(qe));
	return qe->size;
}
void QEDestory(QE* qe)
{
	assert(qe);
	qe->head = qe->tail = NULL;
	qe->size = 0;
	free(qe->head);
	free(qe->tail);

}

test.c

#include"QE.h"

void test()
{
	QE qe = {0};
	QEInit(&qe);
	QEPush(&qe, 1);
	QEPush(&qe, 2);
	QEPush(&qe, 3);
	QEPush(&qe, 4);
	printf("队列数量%d\n", QESize(&qe));

	while (!QEempty(&qe))
	{
		QEnode* ret = QETop(&qe);
		printf("%d ", ret->val);
		QEPop(&qe);
		
	}
	printf("\n队列数量%d", QESize(&qe));

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

四.结言

好了我么队列和栈就以及全部说完了,感谢大家的关注。

有喜欢的兄弟们可以一键三连!!

谢谢大家了,拜拜。

相关推荐
代码游侠3 分钟前
学习笔记——ESP8266 WiFi模块
服务器·c语言·开发语言·数据结构·算法
0和1的舞者4 分钟前
Python 中四种核心数据结构的用途和嵌套逻辑
数据结构·python·学习·知识
利刃大大8 分钟前
【RabbitMQ】Simple模式 && 工作队列 && 发布/订阅模式 && 路由模式 && 通配符模式 && RPC模式 && 发布确认机制
rpc·消息队列·rabbitmq·队列
乌萨奇也要立志学C++11 小时前
【洛谷】递归初阶 三道经典递归算法题(汉诺塔 / 占卜 DIY/FBI 树)详解
数据结构·c++·算法
鱼跃鹰飞12 小时前
Leetcode1891:割绳子
数据结构·算法
Felven12 小时前
A. Helmets in Night Light
c语言
Illusionna.14 小时前
C语言自动进行独立样本 t 检验
c语言·自动化·显著性·统计检验·独立样本t检验·ttest·levene
qq_4017004114 小时前
C语言 条件编译宏
c语言·开发语言
逑之14 小时前
C语言笔记5:函数
java·c语言·笔记
无限进步_14 小时前
【C语言&数据结构】对称二叉树:镜像世界的递归探索
c语言·开发语言·数据结构·c++·git·算法·visual studio