数据结构学习日记(3)——环形队列的代码实现


#ifndef  MYQUEUE_H
#define  MYQUEUE_H

class MyQueue
{
public:
    MyQueue(int QueueCapcity);
    virtual ~MyQueue();
    void ClearQueue();
    bool QueueEmpty() const;
    bool QueueFull() const;
    int QueueLength();
    bool EnQueue(int element);
    bool DeQueue(int &element);
    void QueueTraverse(); // void QueueTraverse( Q visit()) 访问复杂对象的时候需要定义访问方法函数

private:
    int *m_Queue;
    int m_iQueueLen;
    int m_iQueueCapacity;
    int m_Head;
    int m_Tail;
};
MyQueue::MyQueue(int QueueCapcity)
{
    m_iQueueCapacity = QueueCapcity;
    m_Head = 0;
    m_Tail = 0;
    m_Queue = new int[m_iQueueCapacity]; //从堆中申请内存可能会失败
    m_iQueueLen = 0;
}

MyQueue::~MyQueue()
{
    delete[]m_Queue;
    m_Queue = NULL;
}

void MyQueue::ClearQueue()
{
    m_Head = 0;
    m_Tail = 0;
    m_iQueueLen = 0;
}

bool MyQueue::QueueEmpty() const
{
    return  m_iQueueLen == 0 ? true : false;
}

int MyQueue::QueueLength()
{
    return m_iQueueLen;
}

bool MyQueue::QueueFull() const
{
    if (m_iQueueLen == m_iQueueCapacity)
        return true;
    else
        return false;
}

bool MyQueue::EnQueue(int element)
{
    if (QueueFull())
        return false;
    else
    {
        m_Queue[m_Tail] = element;
        m_Tail++;
        m_Tail = m_Tail % m_iQueueCapacity; //实现环形队列的重要一步
        m_iQueueLen++;
        return true;
    }
}

bool MyQueue::DeQueue(int &element)
{
    if (QueueEmpty())
        return false;
    else
    {   
        element = m_Queue[m_Head];
        m_iQueueLen--;
        m_Head++;
        m_Head = m_Head % m_iQueueCapacity; //实现环形队列的重要一步
        return true;
    }
}

void MyQueue::QueueTraverse()
{

    for (int i(m_Head); i < m_iQueueLen + m_Head; ++i)
    {
        cout << m_Queue[i%m_iQueueCapacity] << ','; //实现环形队列的重要一步
    }
}


#endif

环形队列比普通队列来讲内存的管理更加方便,对于内存的浪费的影响较小。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值