最近学习了数据结构队列,队列是一种特殊的线性表,是被限定了的线性表,先进先出(FIFO, First in First out),跟栈的后进先出(LIFO, Last in First out)是类似的一种数据结构,对于这个数据结构,已经有很多的文章有过介绍了,这里也就不再赘述,直接贴出代码,希望能够互相进步!
这里使用了一个HeadNode的节点来表示一个队列,里面只有两个信息,分别是指向队列队首和指向队列队尾的两个指针,这样写,个人认为会更加方便,也不需要进行一些指针的返回。
#include <cstdlib>
#include <iostream>
using namespace std;
typedef int Elemtype;
typedef struct node{
Elemtype data;
node *next;
}Queue;
typedef struct{
Queue *front, *end;
}HeadNode;
/*
*1.初始化一个队列
*2.入队
*3.出队
*4.获取队首元素
*5.判断队列是否为空
*/
bool isEmpty(HeadNode *hd) {
return (hd -> front == NULL ? true : false);
}
HeadNode *initQueue() {
HeadNode *p = new HeadNode;
if (p == NULL) {
cout << "分配内存失败!请重试!