链队列的基本操作

#include<iostream>
#define SIZE    10
using namespace std;
typedef int Type;

typedef struct qnode{
        Type    data;
        qnode   *next;
        }qnode,*queue_pp;
typedef struct {
        queue_pp front;
        queue_pp rear;
        int      qlen;
}linkqueue;

int initqueue(linkqueue &q){ //构造空队列
    q.front = q.rear = new qnode;
    if(!q.front) return 0;
    q.front->next = NULL;
    q.qlen = 0;
    return 1;
}
int destroyqueue(linkqueue &q) { //撤销队列
    while(q.front) {
    q.rear = q.front->next;
    delete q.front;
    q.front = q.rear;
}
    return 1;
}
int insertqueue(linkqueue &q,Type e) { //插入元素e为新的队尾元素
    qnode *p;
    p = new qnode;
    if(!p) return 0;
    p->data = e; p->next = NULL;
    q.rear->next = p;
    q.rear = p;
    ++q.qlen;
    return 1;
}
int deletequeue(linkqueue &q,Type e) { //删除队头元素
    if(q.front == q.rear) return 0;
    qnode *p;
    p = q.front->next;
    e = p->data;
    q.front->next = p->next;
    if(q.rear == p) q.rear = q.front;
    delete q.front;
    --q.qlen;
    return 1;
}
int queueexist(linkqueue &q) {return q.front == 0;} //队列是否存在
int queueclear(linkqueue &q) { //置为空队
    qnode *e;
    e = q.front->next;
    delete q.front;
    q.front = e;
}
int queueempty(linkqueue &q){return q.front == q.rear;} //队列空为真
int queuelength(linkqueue q){cout<<q.qlen<<endl;}//队列元素个数
int queueshow(linkqueue &q)   //输出队列元素
{
    if(queueempty(q) || queueexist(q))
    cout<<"队中没有元素"<<endl;
    else {
    qnode *p;
    p = q.front->next;
    while(p) {
    cout<<p->data<<" ";
    p = p->next;}
}
}


int main()
{
    cout<<"□□□□队列基本操作□□□□"<<endl;
    cout<<"□□□ 1.建立空队列 □□□□"<<endl;
    cout<<"□□□ 2.插入队列 □□□□□"<<endl;
    cout<<"□□□ 3.删除队头元素 □□□"<<endl;
    cout<<"□□□ 4.返回队列长度 □□□"<<endl;
    cout<<"□□□ 5.判断队列是否为空 □"<<endl;
    cout<<"□□□ 6.清空队列 □□□□□"<<endl;
    cout<<"□□□ 7.撤销队列 □□□□□"<<endl;
    cout<<"□□□ 8.输出队列 □□□□□"<<endl;
    cout<<"□□□ 0.退出 □□□□□□□"<<endl;
   
    linkqueue qq;
    int ch;
    Type e;
    while(1) {
    cout<<endl;
    cout<<"请输入你的选择"<<endl;
    cin>>ch;
         switch(ch)
         {
              case 1:
                   initqueue(qq);
                   cout<<"队列已建立"<<endl;
                   break;
              case 2:
                   if(queueexist(qq))break;
                   cout<<"你入队元素是:";
                   cin>>e;
                   insertqueue(qq,e);
                   cout<<"队中元素:";
                   queueshow(qq);
                   break;
              case 3:
                   if(queueexist(qq))
                   break;
                   deletequeue(qq,e);
                   cout<<"您删除的元素是"<<e;
                   queueshow(qq);
                   break;
              case 4:
                   queuelength(qq);
                   break;
              case 5:
                   if(queueempty(qq))
                   cout<<"队为空"<<endl;
                   else {
                   cout<<"队未空"<<endl;}
                   break;
              case 6:
                   queueclear(qq);
                   break;
              case 7:
                   destroyqueue(qq);
                   break;
              case 8:
                   queueshow(qq);
                   break;
              case 0:
                   exit(0);
                   break;
              default:
                 cout<<"输入错误,请重新输入选择"<<endl;
                 break;                          
        }       
    }
           system("pause");   
           return 1;
}

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值