循环队列实现

循环队列结构和基本方法实现:SqQueue.h

#include<iostream>
#include<cstdio>
#include<cstdlib>
#define MAX_SIZE 5//最大队列长度为5+1
typedef int QElemType;
struct SqQueue
{
    QElemType *base;//初始化的动态分配存储空间 
    int front;//头指针,若队列不空,指向队列列头元素 
    int rear;//尾指针,若队列不空,指向队列尾元素的下一个位置  
}; 

//初始化循环队列
bool InitSqQueue(SqQueue &Q)
{
    Q.base = (QElemType *)malloc(MAX_SIZE*sizeof(QElemType));
    if(!Q.base)  return false;
    Q.front = Q.rear = 0;//初始化头尾指针
    return true; 
} 

//销毁循环队列
bool DestroySqQueue(SqQueue &Q)
{
    if(Q.base)//队列存在 
    {
        free(Q.base);//释放Q.base所指的存储空间 
        Q.base = NULL;//Q.base不指向任何存储单元 
        Q.front = Q.rear = 0;
        return true;
    }
    return true;    
} 

//清空循环队列
void ClearSqQueue(SqQueue &Q)
{
    Q.front = Q.rear = 0;//头尾指针初始为0 
} 

//循环队列判空 
bool SqQueueEmpty(SqQueue &Q)
{
    if(Q.front == Q.rear)//队列为空 
        return true;
    return false;   
} 

//返回队头元素
bool GetHead(SqQueue &Q,QElemType &e)
{
    if(Q.front == Q.rear)//队列为空 
        return false;
    e = Q.base[Q.front];
    return true;
} 

//循环队列长度
int QueueLength(SqQueue &Q)
{
    return (Q.rear-Q.front+MAX_SIZE)%MAX_SIZE;//队头,队尾指针会发生变化,防止出现负数 
} 

//插入元素
bool EnSqQueue(SqQueue &Q,QElemType e)
{
    if((Q.rear+1)%MAX_SIZE == Q.front)//队列满 
        return false;
    Q.base[Q.rear] = e;//将e插入队尾
    Q.rear = (Q.rear+1)%MAX_SIZE;//队尾指针+1后对MAX_SIZE取余 
    return true;    
} 

//删除队头元素
bool DeSqQueue(SqQueue &Q,QElemType &e)
{
    if(Q.front == Q.rear) 
        return false;
    e = Q.base[Q.front];//将队头元素的值赋给e
    Q.front = (Q.front+1)%MAX_SIZE;//队头指针+1后对MAX_SIZE取余 
} 

//遍历队列
void QueueTraverse(SqQueue Q)
{
    int i = Q.front;
    while(i!=Q.rear)
    {
        printf("%d ",Q.base[i]);
        i = (i+1)%MAX_SIZE;//i指向下一个元素   
    }   
} 

测试SqQueueMain.cpp:

#include<iostream>
#include<cstdio>
#include<cstdlib>
using namespace std;

typedef int QElemType;

#include"SqQueue.h"
SqQueue Q;
QElemType e;
int main()
{
    if(InitSqQueue(Q))  cout<<"循环队列初始化成功"<<endl;
    if(SqQueueEmpty(Q)) cout<<"该队列为空队列"<<endl; 
    cout<<"请输入"<<MAX_SIZE-1<<"个元素:"<<endl;
    for(int i = 0;i<MAX_SIZE-1;i++)
    {
        cin>>e;
        EnSqQueue(Q,e);
    }
    cout<<"队列长度为"<<QueueLength(Q)<<endl;
    GetHead(Q,e);
    cout<<"队头元素为"<<e<<endl;
    DeSqQueue(Q,e);
    cout<<"删除队头元素"<<e<<endl;
    QueueTraverse(Q);
    cout<<endl;
    ClearSqQueue(Q);
    if(SqQueueEmpty(Q)) cout<<"该队列为空队列"<<endl;
    if(DestroySqQueue(Q)) cout<<"该队列被销毁"<<endl; 
    return 0;
}

测试结果:
这里写图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值