C++__迴圈隊列(練習)

來源:互聯網
上載者:User

標籤:int   getc   else   enqueue   generate   creat   return   ios   sig   

迴圈隊列

 

queue.h

#ifndef QUEUE_H_#define QUEUE_H_#define SIZE 10typedef int data_type;enum QUEUE_OP {    QUEUE_ERR = -1, QUEUE_OK, QUEUE_EMPTY};class QUEUE {private:    data_type *data;    int count;    int iFront;    int iRear;public:    QUEUE();    ~QUEUE();    int getCount() const;    data_type getData(unsigned int i) const;    data_type *getData() const;    int getFront() const;    int getRear() const;    void setCount(int count);    void setData(data_type data, unsigned int i);    void setData(data_type *data);    void setFront(int front);    void setRear(int rear);//    QUEUE *Create();//    void Destroy(QUEUE *pQueue);    int EnQueue(QUEUE *pQueue, data_type tData);    int DeQueue(QUEUE *pQueue, data_type *pData);    int IsEmpty(QUEUE *pQueue);    void operator delete(void *pQueue);};#endif /* QUEUE_H_ */

 

queue.cpp

#include "QUEUE.h"#include <iostream>using namespace std;QUEUE::QUEUE() {    // TODO Auto-generated constructor stub    cout<<"queue"<<endl;    this->setCount(0);    this->setFront(0);    this->setRear(0);    int *data = new data_type[SIZE];    if (!data) {        cout << "new data[SIZE] error" << endl;        this->setData(NULL);    } else {        this->setData(new data_type[SIZE]);    }}QUEUE::~QUEUE() {    // TODO Auto-generated destructor stub    cout<<"~queue"<<endl;}int QUEUE::getCount() const {    return count;}data_type QUEUE::getData(unsigned int i) const {    return data[i];}data_type *QUEUE::getData() const {    return data;}int QUEUE::getFront() const {    return iFront;}int QUEUE::getRear() const {    return iRear;}void QUEUE::setCount(int count) {    this->count = count;}void QUEUE::setData(data_type data, unsigned int i) {    this->data[i] = data;}void QUEUE::setData(data_type *data) {    this->data = data;}void QUEUE::setFront(int front) {    iFront = front;}void QUEUE::setRear(int rear) {    iRear = rear;}int QUEUE::EnQueue(QUEUE *pQueue, data_type tData) {    if (!pQueue)        return QUEUE_ERR;    if (SIZE == pQueue->getCount()) {        cout << "queue en over" << endl;        return QUEUE_ERR;    }    pQueue->setData(tData, pQueue->getRear());    pQueue->setRear(pQueue->getRear() + 1);    if(SIZE == pQueue->getRear())        pQueue->setRear(0);    pQueue->setCount(pQueue->getCount() + 1);    return QUEUE_OK;}int QUEUE::DeQueue(QUEUE *pQueue, data_type *pData) {    if ((!pQueue) || (!pData))        return QUEUE_ERR;    if (0 == pQueue->getCount()) {        cout << "queue de over" << endl;        return QUEUE_ERR;    }    *pData = pQueue->getData(pQueue->getFront());    pQueue->setFront(pQueue->getFront() + 1);    if(SIZE == pQueue->getFront())        pQueue->setFront(0);    pQueue->setCount(pQueue->getCount() - 1);    return QUEUE_OK;}int QUEUE::IsEmpty(QUEUE *pQueue) {    if(!pQueue)        return QUEUE_ERR;    if(0 == pQueue->getCount())        return QUEUE_EMPTY;    return QUEUE_OK;}void QUEUE::operator delete(void *pQueue){    if(!pQueue)        return;    data_type *Tmp = ((QUEUE *)pQueue)->getData();    free(Tmp);    free(pQueue);    return;}

 

main.cpp

#include "QUEUE/QUEUE.h"#include <iostream>using namespace std;void function() {    QUEUE *pQueue = new QUEUE;    if (!pQueue) {        cout << "new queue error" << endl;        return;    }    int i = 5;    data_type data = 0;    while (i--) {        pQueue->EnQueue(pQueue, i);        pQueue->DeQueue(pQueue, &data);        cout << data << "  ";    }    if (QUEUE_OK == pQueue->IsEmpty(pQueue))        cout << "queue ok" << endl;    /*     i = 9;     while (i--) {     pQueue->DeQueue(pQueue, &data);     cout << data << "  ";     }     cout << endl;     if (QUEUE_EMPTY == pQueue->IsEmpty(pQueue))     cout << "queue empty" << endl;     */    delete pQueue;}int main() {    function();    return 0;}

 

C++__迴圈隊列(練習)

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.