DS-队列

概述

​ 只允许在一端插入数据操作,在另一端进行删除数据操作的特殊线性表;进行插入操作的一端称为队尾(入队列),进行删除操作的一端称为队头(出队列);队列具有先进先出(FIFO)的特性

Myqueue

​ 基于数组的队列的实现

MyselfArray

链接: DS-数组

Queue

创建queue接口定义方法

package queue.classdemo;

/**
 * 实现一个自己创建的队列接口
 *
 * @author Deevan
 */
public interface Queue<T> {
    /**
     * 判断队列是否为空
     *
     * @return boolean
     */
    boolean isEmpty();

    /**
     * 获取队列实际元素个数
     *
     * @return int
     */
    int getSize();

    /**
     * 入队,在对尾添加元素
     *
     * @param ele 添加元素内容
     */
    void enqueue(T ele);

    /**
     * 出队并返回内容
     *
     * @return 对首元素
     */
    T dequeue();

    /**
     * 获取对首元素内容
     *
     * @return 对首元素
     */
    T getFront();
}

MyQueue

package queue.classdemo;

/**
 * 定义属于自己的队列
 *
 * @author Deevan
 */
public class MyQueue<T> implements Queue<T> {

    MyselfArray<T> myselfArray;

    MyQueue() {
        this(10);
    }

    public MyQueue(int capacity) {
        myselfArray = new MyselfArray<>(capacity);
    }


    @Override
    public boolean isEmpty() {
        return myselfArray.isEmpty();
    }

    @Override
    public int getSize() {
        return myselfArray.getSize();
    }

    @Override
    public void enqueue(T ele) {
        myselfArray.addTail(ele);
    }

    @Override
    public T dequeue() {
        return myselfArray.removeHead();
    }

    @Override
    public T getFront() {
        return myselfArray.getFirstEle();
    }

    @Override
    public String toString() {
        return "myQueue=" + myselfArray;
    }
}
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

EnndmeRedis

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

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

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

打赏作者

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

抵扣说明:

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

余额充值