c++实现循环队列

时间:2023-03-08 23:52:49
c++实现循环队列
#include <iostream>
#include<stdio.h>
#include<stdlib.h> using namespace std;
int len=;// the len of the que
typedef struct que{
int *qbase;
int fr;
int tr;
}ques;
bool isempty(ques *ptr)
{
if(ptr->fr==ptr->tr)
{
return true;
}
return false; }
bool isfull(ques *ptr)
{
if((ptr->tr+)%len==ptr->fr)
{
return true;
}
return false;
}
void initque(ques *ptr)
{
ptr->qbase=(int *)malloc(sizeof(int)*len);
//不判断内存是否申请失败了哈。。。
ptr->fr=ptr->tr=;
}
void enque(ques *ptr,int val)
{
if(isfull(ptr))
{
cout<<"满了,填不进去了"<<endl;
}
else{ ptr->qbase[ptr->tr]=val;
ptr->tr=(ptr->tr+)%len;
cout<<"en que ok"<<endl;
} }
void dque(ques *ptr)
{
if(isempty(ptr))
{
cout<<"队列空了"<<endl;
}
else{
ptr->qbase[ptr->fr]=;
ptr->fr=(ptr->fr+)%len;
} }
void printque(ques *q)
{
if(isempty(q))
{
cout<<"空队列"<<endl;
}
else{
int i=q->fr;
while(i!=q->tr)
{
cout<<q->qbase[i]<<" "<<endl;
i=(i+)%len;
}
}
}
int main()
{
ques q={NULL,,};//表示一个队列 cout<<isfull(&q)<<endl;
cout<<isempty(&q)<<endl;
initque(&q);
enque(&q,);
enque(&q,);
enque(&q,);
enque(&q,);
dque(&q);
printque(&q);
cout << "Hello world!" << endl;
return ;
}