当前位置: 首页 > news >正文

建立队列,插入队列,删除队列

代码:

#include<iostream>
using namespace std;
template<class T>
class sq_Queue
{private:int mm;int front;int rear;int s;T *q;
public:sq_Queue(int);void prt_sq_Queue();int flag_sq_Queue();void ins_sq_Queue(T);T del_sq_Queue();
};
template<class T>
sq_Queue<T>::sq_Queue(int m)
{mm=m;q=new T[mm];front=mm;rear=mm;s=0;return;
}
template<class T>
void sq_Queue<T>::prt_sq_Queue()
{int i;cout<<"front="<<front<<endl;cout<<"rear="<<rear<<endl;if(s==0){cout<<"队列空!"<<endl;return;}i=front;do{i=i+1;if(i==mm+1)i=1;cout<<q[i-1]<<endl;}while(i!=rear);return;
}
template<class T>
int sq_Queue<T>::flag_sq_Queue()
{if((s==1)&&(rear==fornt))return(-1);if(s==0)return 0;return(1);
}
template<class T>
void sq_Queue<T>::ins_sq_Queue(T x)
{if((s==1)&&(rear==front)){cout<<"Queue_overflow!"<<endl;return;}rear=rear+1;if(rear==mm+1)rear=1;q[rear-1]=x;s=1;return;
}
template<class T>
T sq_Queue<T>::del_sq_Queue()
{T y;if(s==0){cout<<"Queue_underflow!"<<endl;return(0);}front=front+1;if(front==mm+1)front=1;y=q[front-1];if(front==rear)s=0;return(y);}
int main()
{sq_Queue<int> q(10);cout<<"输出排头与队尾指针以及队中元素:"<<endl;q.prt_sq_Queue();q.ins_sq_Queue(50);q.ins_sq_Queue(60);q.ins_sq_Queue(70);q.ins_sq_Queue(80);q.ins_sq_Queue(90);q.ins_sq_Queue(100);cout<<"输出排头与队尾指针以及队中元素:"<<endl;q.prt_sq_Queue();cout<<"输出退队元素:"<<endl;cout<<q.del_sq_Queue()<<endl;cout<<q.del_sq_Queue()<<endl;cout<<q.del_sq_Queue()<<endl;cout<<"输出排头与队尾指针以及队中元素:"<<endl;q.prt_sq_Queue();return 0;
}

运行效果:


http://www.mrgr.cn/news/36276.html

相关文章:

  • Python 如何使用 unittest 模块编写单元测试
  • Linux:编译,调试和Makefile
  • [智能控制】【第2 章 模糊控制的理论基础】
  • 【算法】贪心+堆排序实现大根堆及标准库容器类的融合使用
  • 9.25度小满一面
  • 如何使用 python 调用 llama3 进行对话?
  • 实验19:ds18b20温度实验
  • Python文件操作
  • 前端三大框架对比与选择
  • 看Threejs好玩示例,学习创新与技术(GridDistortionEffect)
  • 持续学习与创新能力的双重提升
  • 天润融通发布微藤智能体平台,中国客户联络正式进入“智能体时代”
  • Stable Diffusion的高分辨率修复(Hires.fix)
  • ESP32,制作一个遥控点火玩具
  • Axios
  • JavaScript的执行上下文和执行栈
  • Spring 的依赖注入原理
  • 【裸机装机系列】15.kali(ubuntu)-重装linux步骤
  • 使用openpyxl轻松操控Excel文件
  • Pandas和Seaborn可视化详解