Java实现队列结构的详细代码

一、什么是队列结构

一种线性结构,具有特殊的运算法则【只能在一端(队头)删除,在另一端(队尾)插入】。

分类:

  1. 顺序队列结构
  2. 链式队列结构

基本操作:

  1. 入队列
  2. 出队列

二、准备数据

复制代码
 1 static final int QUEUELEN = 15;
 2 
 3 class DATA{
 4     
 5     String name;
 6     int age;
 7 }
 8 
 9 class SQType{
10     DATA[] data = new DATA[QUEUELEN];
11     int head;
12     int tail;   
13 }
复制代码

在类SQType中data为数据元素,head为队头序号,tail为队尾序号,当head为0时队为空,当tail为QUEUELEN时表示队列已满。

 

三、初始化队列

在使用队列前首先要创建个空队列,即初始化队列。

  1. 按符号常量QUEUELEN指定的大小申请一片内存空间用来保存对列中的数据。
  2. 设置head=0和tail=0,表示一个空队列。
复制代码
 1 SQType SQTypeInit(){
 2     SQType q;
 3     if((q=new SQType())!=null){      //申请内存
 4         q.head = 0;
 5         q.tail = 0;
 6         return q;
 7     }
 8     else
 9     {
10         return null;
11     }
12 }
复制代码

四、判断空队列

复制代码
1 int SQTypeIsEmpty(SQType q){
2     int temp = 0;
3     if(q.head==q.tail)
4     {
5         temp = 1;
6     }
7     return temp;
8 }
复制代码

五、判断满队列

1 int SQTypeIsFull(SQType q){
2     int temp = 0;
3     if(q.tail==QUEUELEN)
4         temp = 1;
5     return temp;
6 }

六、请空队列

1 void SQTypeClear(SQType q){
2     q.head = 0;
3     q.tail = 0;
4 }

七、释放空间

1 void SQTypeFree(SQType q){
2     
3     if(q!=null){
4         q = null;
5     }
6 }

八、入队列

复制代码
 1 int InSQType(SQType q,DATA data){
 2     if(SQTypeIsEmpty(q)==1){
 3         System.out.println("队列已满,操作失败!");
 4         return 0;
 5     }
 6     else
 7     {
 8         q.data[q.tail++]=data;
 9         return 1;
10     }
11     
12 }
复制代码

九、出队列

复制代码
 1 DATA OutSQType(SQType q){
 2     if(SQTypeIsEmpty(q)==1)
 3     {
 4         System.out.println("队列为空");
 5         return null;
 6     }
 7     else 
 8     {
 9         return q.data[q.head++];
10     }
11     return null
12 }
复制代码

十、读取节点

复制代码
 1 DATA PeekSQType(SQType q){
 2     if(SQTypeIsEmpty(q)==1)
 3     {
 4         System.out.println("队列为空");
 5         return null;
 6     }
 7     else 
 8     {
 9         return q.data[q.head];
10     }
11     return null
12 }
复制代码

十一、计算队列长度

1 int SQTypeLen(SQType q){
2     int temp;
3     temp = q.tail - q.head;
4     return temp;
5 }
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值