[数据结构]队列之顺序队列的类模板实现

2024-09-08 08:08

本文主要是介绍[数据结构]队列之顺序队列的类模板实现,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

队列是一种限定存取位置的线性表,允许插入的一端叫做队尾(rear),允许删除的一端叫做队首(front)。

队列具有FIFO的性质

队列的存储表示也有两种方式:基于数组的,基于列表的。基于数组的叫做顺序队列,基于列表的叫做链式队列。


一下是基于动态数组的顺序队列的模板类的实现。


顺序队列的抽象基类如下所示:只提供了接口和显式的默认构造函数和析构函数,在派生类中调用。

#ifndef QUEUE
#define QUEUE
//队列的抽象基类template<class T>
class Queue
{
public:Queue(){}~Queue(){}virtual bool EnQueue(const T& x)=0;virtual bool DeQueue(T& x)=0;virtual bool getFront(T& x)const=0;virtual bool IsEmpty()const=0;virtual bool IsFull()const=0;virtual int getSize()const=0;
};#endif


顺序队列的具体实现如下:(覆盖所有纯虚函数的接口,并提供自己的接口和数据成员)


/
#include"Stack.h"
#include <iostream>
//#include <cstdlib>
#include <cassert>
using namespace std;template<class T>
class SeqQueue:public Queue<T>
{
public:SeqQueue(int sz=10):front(0),rear(0),maxSize(sz),elements(new T[sz]){assert(elements!=NULL);}~SeqQueue(){delete []elements;}SeqQueue(const SeqQueue<T>& rhs);SeqQueue<T>& operator=(const SeqQueue<T>& rhs);bool EnQueue(const T& x);bool DeQueue(T& x);bool getFront(T& x)const;bool IsEmpty()const{return (rear==front)?true:false;}   //判断空bool IsFull()const{return ((rear+1)%maxSize==front)?true:false;}    //判断满int getSize()const{return (rear-front+maxSize)%maxSize;}    //检测大小,+maxSize表示非负void makeEmpty(){front=rear=0;}friend ostream& operator<< <T>(ostream& os,const SeqQueue<T>& rhs);//注意<T>protected:int front,rear;T* elements;int maxSize;
};template<class T>
bool SeqQueue<T>::EnQueue(const T& x)
{if(IsFull())return false;elements[rear]=x;rear=(rear+1)%maxSize;//注意不是++rearreturn true;
}template<class T>
bool SeqQueue<T>::DeQueue(T& x)
{if(IsEmpty())return false;x=elements[front];front=(front+1)%maxSize;return true;
}template<class T>
bool SeqQueue<T>::getFront(T& x)const
{if(IsEmpty())return false;x=elements[front];return true;
}template<class T>
ostream& operator<<(ostream& os,const SeqQueue<T>& rhs)
{os<<"front="<<rhs.front<<" "<<"rear="<<rhs.rear<<endl;os<<"elements: ";for(int i=0;i<rhs.getSize();++i){os<<rhs.elements[(rhs.front+i)%rhs.maxSize]<<" ";   //注意遍历方法}os<<endl;return os;
}template<class T>
SeqQueue<T>::SeqQueue(const SeqQueue<T>& rhs)
{front=rhs.front;rear=rhs.rear;maxSize=rhs.maxSize;T* dest=new T[maxSize];T* src=rhs.elements;elements=dest;for(int i=0;i<rhs.getSize();++i){dest[(front+i)%maxSize]=src[(front+i)%maxSize];}
}template<class T>
SeqQueue<T>& SeqQueue<T>::operator=(const SeqQueue<T>& rhs)
{delete[] elements;makeEmpty();front=rhs.front;rear=rhs.rear;maxSize=rhs.maxSize;T* dest=new T[maxSize];T* src=rhs.elements;elements=dest;for(int i=0;i<rhs.getSize();++i){dest[(front+i)%maxSize]=src[(front+i)%maxSize];}return *this;
}

测试代码如下:


int main(int argc, char* argv[])
{SeqQueue<int> s(5);int a=1,b=2,c=3,d=4,e=0;s.EnQueue(a);s.EnQueue(b);s.EnQueue(c);s.EnQueue(d);cout<<s;s.DeQueue(e);s.DeQueue(e);cout<<s;cout<<"getSize(): "<<s.getSize()<<endl;cout<<boolalpha;cout<<"IsEmpty(): "<<s.IsEmpty()<<endl;cout<<"IsFull(): "<<s.IsFull()<<endl;cout<<noboolalpha;s.getFront(e);cout<<"getFront(): "<<e<<endl;SeqQueue<int> s1(s),s2;cout<<s1;s2=s;cout<<s2;system("pause");return 0;
}


测试结果如下:


front=0 rear=4
elements: 1 2 3 4
front=2 rear=4
elements: 3 4
getSize(): 2
IsEmpty(): false
IsFull(): false
getFront(): 3
front=2 rear=4
elements: 3 4
front=2 rear=4
elements: 3 4
请按任意键继续. . .


注意事项:

1.该实现是正对动态数组存储的循环队列,在逻辑上构成了一个环。

2.rear指向实际队尾位置的下一个位置,front指向的是真正的对头元素所在的位置。

3.初始化时rear=front=0

4.判断空对:front=rear

5.判断满:(rear+1)%maxSize=front。让rear指向front的前一个位置就认为队列已满,所以最多只能存储maxSize-1个元素。这是为了和队列空的判断相区别。

6.对头指正进1:front=(front+1)%maxSize

7.队尾指针进1:rear=(rear+1)% maxSize








这篇关于[数据结构]队列之顺序队列的类模板实现的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1147579

相关文章

如何使用Java实现请求deepseek

《如何使用Java实现请求deepseek》这篇文章主要为大家详细介绍了如何使用Java实现请求deepseek功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1.deepseek的api创建2.Java实现请求deepseek2.1 pom文件2.2 json转化文件2.2

python使用fastapi实现多语言国际化的操作指南

《python使用fastapi实现多语言国际化的操作指南》本文介绍了使用Python和FastAPI实现多语言国际化的操作指南,包括多语言架构技术栈、翻译管理、前端本地化、语言切换机制以及常见陷阱和... 目录多语言国际化实现指南项目多语言架构技术栈目录结构翻译工作流1. 翻译数据存储2. 翻译生成脚本

如何通过Python实现一个消息队列

《如何通过Python实现一个消息队列》这篇文章主要为大家详细介绍了如何通过Python实现一个简单的消息队列,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录如何通过 python 实现消息队列如何把 http 请求放在队列中执行1. 使用 queue.Queue 和 reque

Python如何实现PDF隐私信息检测

《Python如何实现PDF隐私信息检测》随着越来越多的个人信息以电子形式存储和传输,确保这些信息的安全至关重要,本文将介绍如何使用Python检测PDF文件中的隐私信息,需要的可以参考下... 目录项目背景技术栈代码解析功能说明运行结php果在当今,数据隐私保护变得尤为重要。随着越来越多的个人信息以电子形

使用 sql-research-assistant进行 SQL 数据库研究的实战指南(代码实现演示)

《使用sql-research-assistant进行SQL数据库研究的实战指南(代码实现演示)》本文介绍了sql-research-assistant工具,该工具基于LangChain框架,集... 目录技术背景介绍核心原理解析代码实现演示安装和配置项目集成LangSmith 配置(可选)启动服务应用场景

使用Python快速实现链接转word文档

《使用Python快速实现链接转word文档》这篇文章主要为大家详细介绍了如何使用Python快速实现链接转word文档功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 演示代码展示from newspaper import Articlefrom docx import

前端原生js实现拖拽排课效果实例

《前端原生js实现拖拽排课效果实例》:本文主要介绍如何实现一个简单的课程表拖拽功能,通过HTML、CSS和JavaScript的配合,我们实现了课程项的拖拽、放置和显示功能,文中通过实例代码介绍的... 目录1. 效果展示2. 效果分析2.1 关键点2.2 实现方法3. 代码实现3.1 html部分3.2

Python中顺序结构和循环结构示例代码

《Python中顺序结构和循环结构示例代码》:本文主要介绍Python中的条件语句和循环语句,条件语句用于根据条件执行不同的代码块,循环语句用于重复执行一段代码,文章还详细说明了range函数的使... 目录一、条件语句(1)条件语句的定义(2)条件语句的语法(a)单分支 if(b)双分支 if-else(

Java深度学习库DJL实现Python的NumPy方式

《Java深度学习库DJL实现Python的NumPy方式》本文介绍了DJL库的背景和基本功能,包括NDArray的创建、数学运算、数据获取和设置等,同时,还展示了如何使用NDArray进行数据预处理... 目录1 NDArray 的背景介绍1.1 架构2 JavaDJL使用2.1 安装DJL2.2 基本操

最长公共子序列问题的深度分析与Java实现方式

《最长公共子序列问题的深度分析与Java实现方式》本文详细介绍了最长公共子序列(LCS)问题,包括其概念、暴力解法、动态规划解法,并提供了Java代码实现,暴力解法虽然简单,但在大数据处理中效率较低,... 目录最长公共子序列问题概述问题理解与示例分析暴力解法思路与示例代码动态规划解法DP 表的构建与意义动