亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > C++ > 正文

C++實現循環隊列和鏈式隊列的示例

2020-05-23 13:31:50
字體:
來源:轉載
供稿:網友

循環隊列:

1.循環隊列中判斷隊空的方法是判斷front==rear,隊滿的方法是判斷front=(rear+1)%maxSize。(我曾經想過為什么不用一個length表示隊長,當length==maxSize時隊滿)原因就是,在頻繁的隊列操作中,多出一個變量會大量的增加執行時間,所以不如浪費一個數組空間來得劃算。

2.用單鏈表表示的鏈式隊列特別適合于數據元素變動較大的情形,而且不存在溢出的情況。

template<class T>class SeqQueue{ protected:  T *element;  int front,rear;  int maxSize; public:  SeqQueue(int sz=10){   front=rear=0;   maxSize=sz;   element=new T[maxSize];  }  ~SeqQueue(){   delete[] element;  }  bool EnQueue(const T& x){//入隊    if(isFull()) return false;   element[rear]=x;   rear=(rear+1)%maxSize;   return true;  }  bool DeQueue(T& x){//出隊    if(isEmpty()) return false;   x=element[front];   front=(front+1)%maxSize;   return true;  }  bool getFront(T& x){//獲取隊首元素    if(isEmpty()) return false;   x=element[front];   return true;  }  void makeEmpty(){//隊列置空    front=rear=0;  }  bool isEmpty()const{//判斷隊列是否為空    return (rear==front)?true:false;  }  bool isFull()const{//隊列是否為滿    return ((rear+1)%maxSize==front)?true:false;  }  int getSize()const{   return (rear-front+maxSize)%maxSize;  }};

測試代碼如下:

void menu(){ cout<<"1.入隊"<<endl; cout<<"2.獲取隊首元素"<<endl; cout<<"3.出隊"<<endl; cout<<"4.隊列置空"<<endl; cout<<"5.獲取隊中元素數量"<<endl; cout<<"6.退出"<<endl;} void function(int num,SeqQueue<int> *sq){ switch(num){  int x;  case 1:   cin>>x;   sq->EnQueue(x);   break;  case 2:   sq->getFront(x);   cout<<x<<endl;   break;  case 3:   sq->DeQueue(x);   break;  case 4:   sq->makeEmpty();   break;  case 5:   x=sq->getSize();   cout<<x<<endl;   break;   default:   exit(1); }}int main(int argc, char** argv) { SeqQueue<int> *sq=new SeqQueue<int>; int num; while(true){  menu();  cin>>num;  function(num,sq); }  delete sq; return 0; }

之后是鏈式隊列,實現類代碼和測試代碼如下:

#include <iostream>using namespace std;template<class T> struct LinkNode{ T data; LinkNode<T> *link; LinkNode(T& x,LinkNode<T> *l=NULL){  data=x;  link=l; }};template<class T>class LinkedQueue{ protected:  LinkNode<T> *front,*rear; public:  LinkedQueue(){   front=rear=NULL;  }  ~LinkedQueue(){   makeEmpty();  }  bool enQueue(T& x){   if(front==NULL)    front=rear=new LinkNode<T>(x);   else{    rear=rear->link=new LinkNode<T>(x);   }   return true;  }  bool deQueue(T& x){   if(isEmpty()) return false;   LinkNode<T> *p=front;   x=front->data;   front=front->link;   delete p;   return true;  }  bool getFront(T& x)const{   if(isEmpty()) return false;   x=front->data;   return true;  }  void makeEmpty(){   LinkNode<T> *p;   while(front!=NULL){    p=front;    front=front->link;    delete p;   }  }  bool isEmpty()const{   return (front==NULL)?true:false;  }  int getSize()const{   LinkNode<T> *p;   int count=0;   p=front;   while(p!=NULL){    count++;    p=p->link;   }   return count;  }}; void menu(){ cout<<"1.入隊"<<endl; cout<<"2.獲取隊首元素"<<endl; cout<<"3.出隊"<<endl; cout<<"4.隊列置空"<<endl; cout<<"5.獲取隊中元素數量"<<endl; cout<<"6.退出"<<endl;} void function(int num,LinkedQueue<int> *lq){ switch(num){  int x;  case 1:   cin>>x;   lq->enQueue(x);   break;  case 2:   lq->getFront(x);   cout<<x<<endl;   break;  case 3:   lq->deQueue(x);   break;  case 4:   lq->makeEmpty();   break;  case 5:   x=lq->getSize();   cout<<x<<endl;   break;   default:   exit(1); }}int main(int argc, char** argv) { LinkedQueue<int> *lq=new LinkedQueue<int>; int num; while(true){  menu();  cin>>num;  function(num,lq); }  delete lq; return 0; }

以上這篇C++實現循環隊列和鏈式隊列的示例就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持VEVB武林網。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
最近2019年手机中文字幕| 亚洲精品有码在线| 国产精品你懂得| 亚洲女性裸体视频| 国产精品成人aaaaa网站| 一本色道久久88亚洲综合88| 九九精品在线视频| 国产一区二区三区久久精品| 少妇久久久久久| 91爱视频在线| 国产成人一区二| 日韩va亚洲va欧洲va国产| 亚洲高清av在线| 亚洲精品二三区| 国内精品久久久久| 亚洲图片欧美日产| 正在播放欧美视频| 亚洲精品456在线播放狼人| 中文字幕日本精品| 久久成人精品电影| 97欧美精品一区二区三区| 日韩中文字幕在线| 亚洲另类xxxx| 久久精品国产欧美激情| 色综合导航网站| 欧美国产日韩一区二区在线观看| 色爱精品视频一区| 国产精品一区二区三区久久久| 国产精选久久久久久| 国产成人精品日本亚洲专区61| 高清欧美电影在线| 亚洲aaaaaa| 91国产美女视频| 欧美另类交人妖| 国产在线观看精品一区二区三区| 精品无人区乱码1区2区3区在线| 国产精品成人va在线观看| 久久久人成影片一区二区三区观看| 国内精品一区二区三区| 中文字幕日韩欧美在线视频| 疯狂做受xxxx高潮欧美日本| 国产精品视频免费在线| 欧美性感美女h网站在线观看免费| 亚洲精品一区二区在线| 久久久天堂国产精品女人| 欧美国产日产韩国视频| 91精品国产乱码久久久久久蜜臀| 91国产高清在线| 亚洲国产毛片完整版| 日韩经典第一页| 红桃视频成人在线观看| 国产精品爽黄69天堂a| 国产91精品不卡视频| 日韩一区二区欧美| 欧美大成色www永久网站婷| 久久久精品在线| 日本韩国欧美精品大片卡二| 欧美精品videosex牲欧美| 78m国产成人精品视频| 久久免费视频网| 91精品国产亚洲| 亚洲最大av在线| 欧美天堂在线观看| 伊人激情综合网| 国产有码在线一区二区视频| 亚洲欧洲视频在线| 欧美黄色免费网站| 日本高清不卡的在线| 国产自产女人91一区在线观看| 国产成人+综合亚洲+天堂| 亚洲欧美日韩综合| 欧美性极品xxxx做受| 国产精品美女主播| 国产日本欧美一区二区三区在线| 日韩精品免费视频| 久久久久久av| 久久91亚洲精品中文字幕奶水| 亚洲高清久久久久久| 亚洲精品在线看| 亚洲激情在线观看| 国产精品黄页免费高清在线观看| 久久精品视频网站| 欧美日韩国产精品| 久久久极品av| 国产精品福利在线观看网址| 日韩成人在线免费观看| 欧美成aaa人片免费看| 欧美成人在线影院| 欧美激情亚洲自拍| 91精品国产91久久久| 欧美日韩国产第一页| 亚洲精品91美女久久久久久久| 欧美亚洲视频在线看网址| 97久久久免费福利网址| 美女视频黄免费的亚洲男人天堂| 亚洲自拍偷拍网址| 亚洲国产中文字幕久久网| 国产欧美日韩精品丝袜高跟鞋| 国产精品直播网红| 97久久久免费福利网址| 韩国精品久久久999| 久久在线免费视频| 国产日韩欧美黄色| 日韩不卡中文字幕| 国外成人免费在线播放| 91免费欧美精品| 国产一区av在线| 亚洲欧洲一区二区三区久久| 欧美日韩高清区| 久久人人爽人人爽人人片av高清| 亚洲欧美国产视频| 俺去了亚洲欧美日韩| 欧美黄色免费网站| 色伦专区97中文字幕| 亚洲色图在线观看| www.精品av.com| 欧美激情视频在线免费观看 欧美视频免费一| 成人av在线天堂| www.99久久热国产日韩欧美.com| 亚洲免费高清视频| 日本精品久久久久久久| 欧美综合第一页| 在线观看日韩www视频免费| 日韩专区在线播放| 欧美疯狂做受xxxx高潮| 国模叶桐国产精品一区| 国产视频丨精品|在线观看| 久久久国产精品一区| 国产成人中文字幕| 国产欧美一区二区三区久久| 精品av在线播放| 亚洲国产天堂久久综合网| 国产精品永久免费| 日韩美女中文字幕| 久久99久国产精品黄毛片入口| 成人福利在线视频| 在线视频欧美日韩精品| 日韩欧美中文在线| 亚洲一级一级97网| 亚洲国产婷婷香蕉久久久久久| 久久久国产精品一区| 欧美在线一区二区三区四| 亚洲区中文字幕| 亚洲欧美日本伦理| 国产成人精品视频在线观看| 国产精品免费一区豆花| 亚洲欧美另类在线观看| 一区二区三区动漫| 日韩av手机在线| 亚洲第一在线视频| 日韩av不卡电影| 精品中文字幕久久久久久| 亚洲精品免费一区二区三区| 日韩av在线看| 亚洲精品www久久久| 美日韩精品免费观看视频| 色与欲影视天天看综合网| 日韩精品一区二区视频| 久久久精品2019中文字幕神马| 成人久久久久久久| xvideos国产精品| 久久久久久综合网天天| 亚洲黄色www网站| 亚洲男人天天操|