首页 > 其他 > 详细

LinkQueue

时间:2016-10-25 13:38:03      阅读:297      评论:0      收藏:0      [点我收藏+]
template <class T>
class Node
{
public:
    T data;
    Node *next;
    Node () { }
    Node (T d, Node *p): data(d), next(p) { }
};

template <class T>
class Queue
{
private:
    Node<T> *front, *rear;    
    int size; 
public:
    Queue() : rear(NULL), front(NULL) { size = 0; }
    
    ~Queue() { if(!IsEmpty()) makeEmpty(rear); }
    
    bool EnQueue(const T &x)
    {
        rear = new Node<T> (x, rear);
        size++;
        if(!front) front = rear;
    } 
    
    bool DeQueue(T &x)
    {
        if(IsEmpty()) return false;
        x = front->data;
        
        if(front == rear) delete front;
        else{
            Node<T> *p = front;
            front = rear;
            while(front->next != p) front = front->next;
            delete p;
        }
        
        size--;
        return true;
    }
    
    bool getFront(T &x) const //ok
    {
        if(IsEmpty()) return false;
        x = front->data;
        return true;
    }
    
    void makeEmpty(Node<T> *p)
    {
        if(p != rear) makeEmpty(p->next);
        delete p;
    } 
    
    bool IsEmpty() const { return !size ? true : false; }
    
    int getSize() const 
    {
        return size;
    }
};

Mind:Nothing

LinkQueue

原文:http://www.cnblogs.com/QQ-1615160629/p/5996016.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!