C/C++圆形队列

队列特点:

  • 先进先出
  • 只能从队列头部删除元素
  • 只能从队列尾部插入元素

使用:

#include "circlequeue.h"
#include <iostream>
using namespace std;

int main(int argc, char *argv[])
{
    CCircleQueue<int> queue(4);//定义一个容量为4的队列

    int i=1;
    bool ret;
    ret=queue.push_back(i);
    if(!ret)
    {
        cout << "push_back failed" << endl;
    }
    else
    {
        cout << "queue.size() = " << queue.size() << ", queue.space() = " << queue.space() << endl;
    }

    ret=queue.pop_front(0);
    if(!ret)
    {
        cout << "pop_front failed" << endl;
    }
    else
    {
        cout << "queue.size() = " << queue.size() << ", queue.space() = " << queue.space() << endl;
    }

    i=2;
    ret=queue.push_back(i);
    if(!ret)
    {
        cout << "push_back failed" << endl;
    }
    else
    {
        cout << "queue.size() = " << queue.size() << ", queue.space() = " << queue.space() << endl;
    }

    i=3;
    ret=queue.push_back(i);
    if(!ret)
    {
        cout << "push_back failed" << endl;
    }
    else
    {
        cout << "queue.size() = " << queue.size() << ", queue.space() = " << queue.space() << endl;
    }

    i=4;
    ret=queue.push_back(i);
    if(!ret)
    {
        cout << "push_back failed" << endl;
    }
    else
    {
        cout << "queue.size() = " << queue.size() << ", queue.space() = " << queue.space() << endl;
    }

    i=5;
    ret=queue.push_back(i);
    if(!ret)
    {
        cout << "push_back failed" << endl;
    }

    cout << "queue.size() = " << queue.size() << ", queue.space() = " << queue.space() << endl;

    int size=queue.size();
    for(int i=0; i<size; i++)
    {
        cout << "The " << (i+1) << "th is " << queue[i] << endl;
    }

    return 1;
}

输出:

queue.size() = 1, queue.space() = 3
queue.size() = 0, queue.space() = 4
queue.size() = 1, queue.space() = 3
queue.size() = 2, queue.space() = 2
queue.size() = 3, queue.space() = 1
queue.size() = 4, queue.space() = 0
The 1th is 2
The 2th is 3
The 3th is 4
The 4th is 5 

源码:

https://gitee.com/zhangtongxueruanjiankaifa/circular-queue

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

沉淀期待未来9527

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值