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;
}

四.结言

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

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

谢谢大家了,拜拜。

相关推荐
XuanRanDev1 小时前
【每日一题】LeetCode - 三数之和
数据结构·算法·leetcode·1024程序员节
代码猪猪傻瓜coding1 小时前
力扣1 两数之和
数据结构·算法·leetcode
EricWang13582 小时前
[OS] 项目三-2-proc.c: exit(int status)
服务器·c语言·前端
我是谁??2 小时前
C/C++使用AddressSanitizer检测内存错误
c语言·c++
南宫生2 小时前
贪心算法习题其三【力扣】【算法学习day.20】
java·数据结构·学习·算法·leetcode·贪心算法
希言JY2 小时前
C字符串 | 字符串处理函数 | 使用 | 原理 | 实现
c语言·开发语言
午言若2 小时前
C语言比较两个字符串是否相同
c语言
weixin_432702263 小时前
代码随想录算法训练营第五十五天|图论理论基础
数据结构·python·算法·深度优先·图论
passer__jw7674 小时前
【LeetCode】【算法】283. 移动零
数据结构·算法·leetcode
TeYiToKu4 小时前
笔记整理—linux驱动开发部分(9)framebuffer驱动框架
linux·c语言·arm开发·驱动开发·笔记·嵌入式硬件·arm