【C++/数据结构】队列

零.导言

和上次学习的栈一样,队列是一种数据结构,在后续的学习中可能经常使用,因此我们今天就来学习如何实现队列,以更好地使用它。


一.队列的模拟实现

在类(class)Queue 中,包含成员变量和成员函数;同时,队列的实现要相对复杂一些。

我们先看代码:

cpp 复制代码
#include<iostream>
#include<cassert>

using namespace std;

typedef int QueueDataType;

class Queue
{
public:
	Queue()
	{
		_phead = _ptail = nullptr;
		_size = 0;
	}

	~Queue()
	{
		QueueNode* pcur = _phead;
		while (pcur)
		{
			QueueNode* next = pcur->_next;
			free(pcur);
			pcur = next;
		}
		_phead = _ptail = nullptr;
		_size = 0;
	}

	void Push(QueueDataType n)
	{
		QueueNode* newnode = (QueueNode*)malloc(sizeof(QueueNode));
		if (newnode == nullptr)
		{
			perror("malloc fail!");
			exit(1);
		}
		newnode->_val = n;
		newnode->_next = nullptr;
		if (_phead == nullptr)
		{
			_phead = _ptail = newnode;
		}
		else
		{
			_ptail->_next = newnode;
			_ptail = _ptail->_next;
		}
		_size++;
	}

	bool isEmpty()
	{
		return _phead == nullptr;
	}

	void Pop()
	{
		assert(!isEmpty());
		if (_phead == _ptail)
		{
			free(_phead);
			_phead = _ptail = nullptr;
		}
		else
		{
			QueueNode* next = _phead->_next;
			free(_phead);
			_phead = next;
		}
		_size--;
	}

	QueueDataType Front()
	{
		assert(!isEmpty());
		return _phead->_val;
	}

	QueueDataType Back()
	{
		assert(!isEmpty());
		return _ptail->_val;
	}

	int Size()
	{
		return _size;
	}

private:
	class QueueNode
	{
		friend class Queue;
		QueueDataType _val;
		QueueNode* _next;
	};

	QueueNode* _phead;
	QueueNode* _ptail;
	int _size;
};

二.队列的相关解释

如上:队列的实现需要定义两个结构体,第一是 QueueNode ,是链表的节点类型;第二是 Queue ,指向队列的头和尾。

其中:构造函数和析构函数很容易辨认,Push 是向队尾插入数据,Pop 是从队头出数据,Front 是取队头数据,Back 是取队尾数据,Size 是返回有效元素个数。


三.队列的特性

队列的特性是:所有数据都只能从队尾入,从队头出。和堆的形式相反,先进先出。运用这个特性,我们可以便捷的解决堆不好解决的问题。


四.相关链接

【C++/数据结构】栈-CSDN博客


相关推荐
玩代码2 小时前
备忘录设计模式
java·开发语言·设计模式·备忘录设计模式
岁忧2 小时前
(nice!!!)(LeetCode 面试经典 150 题 ) 30. 串联所有单词的子串 (哈希表+字符串+滑动窗口)
java·c++·leetcode·面试·go·散列表
技术猿188702783512 小时前
实现“micro 关键字搜索全覆盖商品”并通过 API 接口提供实时数据(一个方法)
开发语言·网络·python·深度学习·测试工具
放飞自我的Coder3 小时前
【colab 使用uv创建一个新的python版本运行】
开发语言·python·uv
SunkingYang3 小时前
MFC/C++语言怎么比较CString类型最后一个字符
c++·mfc·cstring·子串·最后一个字符·比较
界面开发小八哥3 小时前
MFC扩展库BCGControlBar Pro v36.2新版亮点:可视化设计器升级
c++·mfc·bcg·界面控件·ui开发
R-G-B3 小时前
【15】MFC入门到精通——MFC弹窗提示 MFC关闭对话框 弹窗提示 MFC按键触发 弹窗提示
c++·mfc·mfc弹窗提示·mfc关闭弹窗提示·mfc按键触发 弹窗提示
艾莉丝努力练剑3 小时前
【数据结构与算法】数据结构初阶:详解顺序表和链表(四)——单链表(下)
c语言·开发语言·数据结构·学习·算法·链表
zyhomepage3 小时前
科技的成就(六十九)
开发语言·网络·人工智能·科技·内容运营
十秒耿直拆包选手3 小时前
Qt:QCustomPlot类介绍
c++·qt·qcustomplot