当前位置:网站首页>622. 设计循环队列

622. 设计循环队列

2022-08-03 11:59:00 anieoo

原题链接:622. 设计循环队列

solution:

        

class MyCircularQueue {
public:
    int hh = 0,tt = 0;
    vector<int> q;
    MyCircularQueue(int k) {
        q.resize(k + 1);
    }
    
    bool enQueue(int value) {
        if(isFull()) return false;
        q[tt++] = value;
        if(tt == q.size()) tt = 0;
        return true;
    }
    
    bool deQueue() {
        if (isEmpty()) return false;
        hh ++ ;
        if (hh == q.size()) hh = 0;
        return true;
    }
    
    int Front() {
        if(isEmpty()) return -1;
        return q[hh];
    }
    
   int Rear() {
        if (isEmpty()) return -1;
        int t = tt - 1;
        if (t < 0) t = q.size() - 1;
        return q[t];
    }
    bool isEmpty() {
        return hh == tt;
    }
    
    bool isFull() {
        return (tt + 1) % q.size() == hh;
    }
};

/**
 * Your MyCircularQueue object will be instantiated and called as such:
 * MyCircularQueue* obj = new MyCircularQueue(k);
 * bool param_1 = obj->enQueue(value);
 * bool param_2 = obj->deQueue();
 * int param_3 = obj->Front();
 * int param_4 = obj->Rear();
 * bool param_5 = obj->isEmpty();
 * bool param_6 = obj->isFull();
 */

 

 

原网站

版权声明
本文为[anieoo]所创,转载请带上原文链接,感谢
https://blog.csdn.net/qq_42174306/article/details/126129488