严蔚敏 《数据结构》第三章栈和队列 3.4节循环队列——队列的顺序表示和实现 C++实现

严蔚敏 《数据结构》第三章栈和队列 3.4节循环队列——队列的顺序表示和实现 C++实现

// sq_queue.h
// 循环队列
// by Envirian
#ifndef SQ_QUEUE_H_
#define SQ_QUEUE_H_
#include <bits/stdc++.h>
using namespace std;
// 怠惰ing
using QElemType = int;

class SqQueueClass {
private:
    const int kMAXQSIZE = 100;

private:
    // front_==rear_表示队列为空,rear_的下一个元素为head_表示队列满了
    // 用取余运算来实现循环
    vector<QElemType> queue_;
    int front_;
    int rear_;

public:
    SqQueueClass()
        : queue_{vector<QElemType>(kMAXQSIZE)}, front_{0}, rear_{0} {}

    int QueueLength()
    {
        return (rear_ - front_ + kMAXQSIZE) % kMAXQSIZE;
    }

    bool EnQueue(const QElemType& e)
    {
        if ((rear_ + 1) % kMAXQSIZE == front_)
            // 队列满了
            return false;
        queue_[rear_] = e;
        rear_         = (rear_ + 1) % kMAXQSIZE;
        return true;
    }

    bool DeQueue(QElemType& e)
    {
        if (front_ == rear_)
            // 队列为空
            return false;
        e      = queue_[front_];
        front_ = (front_ + 1) % kMAXQSIZE;
        return true;
    }
};

#endif
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值