c++简单实现循环队列
栈的数据结构是先进后出,而队列的数据结构就是 一个出口一个入口入口只能入队,出口只能出队
实现的代码如下:
/*
循环静态队列实现 2017年8月5日07:50:58
*/
#ifndef __QUEUE_H__
#define __QUEUE_H__
#include <Windows.h>
class Queue
{
public:
Queue(); //无参构造
Queue(DWORD); //有参构造
~Queue(); //析构
BOOL push(UINT); //入队
BOOL pop(UINT&); //出队
void traverse(); //遍历
BOOL isEmpty(); //是否为null
BOOL isFull(); //是否已满
private:
DWORD m_qUeuesize; //队列的数组长度
DWORD m_front; //队列第一个元素索引
DWORD m_rear; // 队列下一个可用元素索引
PDWORD m_pTr; //元素的指针
};
Queue::Queue()
:m_qUeuesize(),
m_front(NULL),
m_rear(NULL)
{
m_pTr = new DWORD[m_qUeuesize];
if(!m_pTr)return;
ZeroMemory(m_pTr,sizeof(DWORD)*m_qUeuesize);
}
Queue::Queue(DWORD dwSize)
:m_qUeuesize(dwSize),
m_front(NULL),
m_rear(NULL)
{
m_pTr = new DWORD[m_qUeuesize];
if(!m_pTr)return;
ZeroMemory(m_pTr,sizeof(DWORD)*m_qUeuesize);
}
Queue::~Queue()
{
if(m_pTr)
delete [] m_pTr;
}
BOOL Queue::push(UINT Element)
{
if (isFull())
{
//队列已满 入队失败
return FALSE;
}else
{
m_pTr[m_rear] = Element;
m_rear = (m_rear+) % m_qUeuesize;
return TRUE;
}
}
BOOL Queue::pop(UINT& Element)
{
if (isEmpty())
{
//队列是null的出队失败
return FALSE;
}else
{
Element = m_pTr[m_front]; //先把要出队的数据返回去
m_front = (m_front+) % m_qUeuesize;
}
return TRUE;
}
BOOL Queue::isEmpty()
{
if (m_front == m_rear)
return TRUE;
else
return FALSE;
}
BOOL Queue::isFull()
{
if((m_rear+) % m_qUeuesize == m_front)
return TRUE;
else
return FALSE;
}
void Queue::traverse()
{
DWORD dwTempIndex = m_front;
while(m_rear!=dwTempIndex)
{
printf("%d\t",m_pTr[dwTempIndex]);
dwTempIndex = (dwTempIndex + ) % m_qUeuesize;
}
printf("\r\n");
}
#endif //__QUEUE_H__
演示代码
#include <stdio.h>
#include <stdlib.h>
#include "Queue.h"
int main(void)
{
UINT m_elem = NULL;
Queue * tempPtr = new Queue();
if (tempPtr->isEmpty())
{
printf("队列是null的\r\n");
}
tempPtr->push();
tempPtr->push();
tempPtr->push();
tempPtr->push();
tempPtr->push();
if(tempPtr->isFull())
{
printf("队列已满\r\n");
}else
{
tempPtr->push();
}
tempPtr->traverse();
tempPtr->pop(m_elem);
printf("m_elem:%d\r\n",m_elem);
tempPtr->traverse();
delete tempPtr;
system("pause");
return ;
}
c++简单实现循环队列的更多相关文章
- Java实现一个简单的循环队列
在某些时候,我们不能被要求像数组一样可以使用索引随机访问,而是需要被限制顺序处理业务,今天介绍一种先进先出(FIFO)的线性数据结构:队列, 当然,还有后进先出(LIFO)的处理方式,即为栈(后续有时 ...
- C++编程练习(5)----“实现简单的循环队列的顺序存储结构“
队列(queue)是只允许在一端进行插入操作,而在另一端进行删除操作的线性表. 队列是一种先进先出(First In First Out)的线性表,简称FIFO.允许插入的一端称为队尾,允许删除的一端 ...
- [从今天开始修炼数据结构]队列、循环队列、PriorityQueue的原理及实现
[从今天开始修炼数据结构]基本概念 [从今天开始修炼数据结构]线性表及其实现以及实现有Itertor的ArrayList和LinkedList [从今天开始修炼数据结构]栈.斐波那契数列.逆波兰四则运 ...
- 数据结构之循环队列Demo
循环队列 比较简单,循环队列主要是判断队满.队空.有效元素个数 画图说明: 假设:队的长度为5(0-4) 但是实际maxsize为6,需要一个预留空间(不存储元素)做计算 继续添加3个元素后: 出队一 ...
- Atitit.提升软件稳定性---基于数据库实现的持久化 循环队列 环形队列
Atitit.提升软件稳定性---基于数据库实现的持久化 循环队列 环形队列 1. 前言::选型(马) 1 2. 实现java.util.queue接口 1 3. 当前指针的2个实现方式 1 1.1 ...
- Atitit.升级软件的稳定性---基于数据库实现持久化 循环队列 循环队列
Atitit.升级软件的稳定性---基于数据库实现持久化 循环队列 环形队列 1. 前言::选型(马) 1 2. 实现java.util.queue接口 1 3. 当前指针的2个实现方式 1 1.1 ...
- 深入理解循环队列----循环数组实现ArrayDeque
我们知道队列这种数据结构的物理实现方式主要还是两种,一种是链队列(自定义节点类),另一种则是使用数组实现,两者各有优势.此处我们将要介绍的循环队列其实是队列的一种具体实现,由于一般的数组实现的队列结构 ...
- C语言实现循环队列
今日在处理数据存储的问题中,数据占用的空间较大,在询问之下,提及循环队列. 没有学习过的我,想想就是头大,只能慢慢从网上找资料,一个字母一个字母的敲,最后,还是慢慢的对队列有了一些理解 对于循环队列有 ...
- 基于数组的循环队列(C++模板实现)
循环队列使用数组实现的话,简单.方便.之前实现的队列,当尾端索引到达队列最后的时候,无论前面是否还有空间,都不能再添加数据了.循环队列使得队列的存储单元可以循环利用,它需要一个额外的存储单元来判断队列 ...
随机推荐
- 走近科学,探究阿里闲鱼团队通过数据提升Flutter体验的真相
背景 闲鱼客户端的flutter页面已经服务上亿级用户,这个时候Flutter页面的用户体验尤其重要,完善Flutter性能稳定性监控体系,可以及早发现线上性能问题,也可以作为用户体验提升的衡量标准. ...
- 10-1 body标签里面相关的标签(列表,表单,表格)
一 列表标签<ul>,<ol>,<dl> <!DOCTYPE html> <html lang="en"> <he ...
- Logtail提升采集性能
默认性能限制 为防止滥用消耗过多机器资源,我们对默认安装的Logtail进行了一系列的资源限制.默认安装的Logtail最多日志采集速度为20M/s,20个并发发送. 其他资源限制请参考:启动参数 h ...
- etcd 在超大规模数据场景下的性能优化
作者 | 阿里云智能事业部高级开发工程师 陈星宇(宇慕) 概述 etcd是一个开源的分布式的kv存储系统, 最近刚被cncf列为沙箱孵化项目.etcd的应用场景很广,很多地方都用到了它,例如kuber ...
- centos下iptables使用
iptables的使用规则: 1.表 (table) 包含4个表(哪个表是当前表取决于内核配置选项和当前模块):4个表的优先级由高到低:raw-->mangle-->nat--> ...
- 20190527-JavaScriptの打怪升级旅行 { 语句 [ 声明 ,变量 ] }
写在前面的乱七八糟:时间总是轻易地溜走,不留一丝念想,近一个月,倒是过得有点丧,从今天开始起,已经开始接触后台了,而JavaScript也只是大致有了个分类框架,那些细枝末节还有的补,任重道远,天将降 ...
- C#面向对象--练习题
public class Program { //用户自定义:我们自己定义这种数据类型 public struct jiegouti// 结构体前面加上public, 可供外界访问 { public ...
- Oracle - @和@@、&与&& 的区别
2018-01-15 15:36:17 袭冷 阅读数 4783更多 分类专栏: DB 版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明. 本文链接 ...
- js 数组的拼接
数组的拼接 var a = [1,2,3,4,5,6]; var b=["foo","bar", "fun"]; 最终的结果是: [ 1,2 ...
- Windows 10 Shared folder - 5168: Spn check for SMB/SMB2 fails.
在搭建 Win10 Shared Folder 时,运行一段时间后就报 Access denied. 导致 Shared Folder 访问不了. 查了下 Event Viewer -> Win ...