数据结构:队列

这篇博客详细介绍了如何利用数组创建一个ArrayQueue类,实现了构造队列、队列满判断、队列空判断、元素入队、元素出队、获取队首元素和打印队列等功能。文中通过具体的步骤解释了每个操作的逻辑,并提供了测试和结果展示。
摘要由CSDN通过智能技术生成

利用数组实现一个队列。(用循环数组实现队列效率更高,后期再补充)其功能包括构造队列、队列判满、队列判空、元素入队、元素出队、获取队首元素、打印队列。


创建一个ArrayQueue类,并声明一些后续需要用到的变量。rear是尾指针,head是头指针,size用于记录队列的大小,数组arr则用于实现队列。

class ArrayQueue{
    private int rear;
    private int head;
    private int size;
    private int[] arr;

    //......

}

一、构造队列

该方法负责创建一个制定大小的数组作为队列,并初始化头指针head和尾指针rear,值为-1。该处将初始值设为-1是为了后续处理方便。

    //构造
    public ArrayQueue(int maxsize){
        size = maxsize;
        arr = new int[size];
        rear = -1;
        head = -1;
    }

二、判断队列是否已满

当头尾指针相距长度为size时,则表示该队列已满。若满足判断则返回true,表示已满;否则,返回false,表示未满。

    //判满
    public boolean isFull(){
        return rear - head == size;
    }

三、判断队列是否为空

当头尾指针重合时(一般此时值为-1),表示已空。同上步骤,返回true或false。

    //判空
    public boolean isEmpty(){
        return rear == head;
    }

四、元素入队

在入队操作时,我们入参element表示需要插入队列的元素。第一步,先判断此时队列是否已满,若已满则抛出异常或者打印“队列已满”提示;如果队列未满,则将rear后移一位,将element放入数组新位置中。(rear设置为-1是为了此处操作一致。)并打印“入队成功!”提示。

    //入队
    public void addQueue(int element){
        if(isFull()){
            //throw new RuntimeException("队列已满!");
            System.out.println("队列已满!");
            return;
        }
        rear++;
        arr[rear] = element;
        System.out.println("入队成功!");
    }

五、元素出队

需要完成出队动作时,第一步也是先判断该队列是否还存在元素,如果队列为空直接抛出异常。如果不为空,则将对首元素记录在ans变量中,然后数组其他元素一次向前移动一个位置,保证队

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Hokachi

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值