队列及其Java实现

队列及其Java实现

​ 队列是一种只允许在表的前端进行删除操作且在表的后端进行插入操作的线性表。其中,执行插入操作的端叫做队尾,执行删除操作端的叫作队头。没有元素的队列叫作空队列,在队列中插入一个队列元素叫作入队,从队列中删除一个队列元素叫作出队。因为队列只允许在队尾插入,在对头删除,所以最早进入队列的元素将最先被从队列中删除,所以队列又叫作先进先出(FIFO-first in first out)线性表。

要实现一个队列,需要先实现如下核心方法。

​ add():向队尾加入一个元素(入队),先入队列的元素在最前边。

​ poll():删除队头的元素(出队)。

​ peek():取出对头的元素。

队列的简单实现如下。

(1)定义队列的数据结构:

public class Queue<E> {
    private Object[] data = null;
    private int maxSize; //队列的大小
    private int front; //对头,允许删除
    private int rear; // 队尾,允许插入
    //构造函数,默认队列的大小为10
    public Queue() {
        this(10);
    }
    public Queue(int initialsize) {
        if(initialsize >= 0) {
            this.maxSize = initialsize;
            data = new Object[initialsize];
            front = rear = 0;
        } else {
            throw new RuntimeException("初始化大小不能小于0:" + initialsize);
        }
    }
}

以上代码定义了一个名为Queue的队列,并定义了用于存储队列数据的data数组、对头位置标记front、队尾位置标记rear、队列的容量maxSize。队列的默认长度为10,在初始化时,front的位置等于rear的位置,都为0;在有新的数据加入队列时,front的值加1。

(2)向队列中插入数据:

//在队尾插入元素
    public boolean add(E e) {
        if(rear == maxSize) {
            throw new RuntimeException("队列已满,无法插入新的元素!");
        } else {
            data[rear++] = e;
            return true;
        }
    }

以上代码定义了add方法来向队列中插入数据,在插入前先判断队列是否满了,如果队列有空间,则通过data[rear++]=e向队尾插入数据并将队尾的指针位置加1。

(3)取走对头数据:

//删除对头的元素:出队
    public E poll() {
        if(front == rear) {
            throw new RuntimeException("空队列异常!");
        } else {
            E value = (E) data [front]; //临时保存队列front端的元素的值
            data[front++] = null;//释放队列front端的元素
            return value;
        }
    }

以上代码定义了poll方法来取走队头的数据,并将队头的数据设置为null以释放队头的位置,最后返回队头的数据。

(4)队列数据查询:

//取出对头的元素,但不删除
    public E peek(){
        if(front == rear) {
            throw new RuntimeException("空队列异常!");
        } else {
            return (E)data[front];
        }
    }

以上代码定义了peek方法来访问并返回队头的数据。

测试样例:

    public static void main(String[] args) {
        // 定义并初始化一个包含字母的String数组
        String[] letters = {"A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M",
                "N", "O", "P", "Q", "R", "S", "T", "U", "V", "W", "X", "Y", "Z"};
        Queue<String> queue = new Queue<String>(26);
        System.out.println(queue.maxSize);
        for (String letter : letters) {
            queue.add(letter);
        }
        System.out.println(queue.peek());
        System.out.println(queue.front);
        System.out.println(queue.rear);
        for (int i = 0; i < 26; i++) {
            System.out.println(queue.poll());
        }
        System.out.println(queue.front);
        System.out.println(queue.rear);
        System.out.println(queue.peek());
        System.out.println(queue.data.length);
    }
  • 5
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
包括但不仅限于链表、栈,队列,树,堆,图等经典数据结构及其他经典基础算法(如排序等)... Java是一种广泛使用的面向对象的编程语言,由Sun Microsystems公司于1995年5月正式发布。它的设计目标是“一次编写,到处运行(Write Once, Run Anywhere)”,这意味着开发者可以使用Java编写应用程序,并在支持Java的任何平台上无需重新编译即可运行,这得益于其独特的跨平台性,通过Java虚拟机(JVM)实现不同操作系统上的兼容。 Java的特点包括: 面向对象:Java全面支持面向对象的特性,如封装、继承和多态,使得代码更易于维护和扩展。 安全:Java提供了丰富的安全特性,如禁止指针运算、自动内存管理和异常处理机制,以减少程序错误和恶意攻击的可能性。 可移植性:Java字节码可以在所有安装了JVM的设备上执行,从服务器到嵌入式系统,再到移动设备和桌面应用。 健壮性与高性能:Java通过垃圾回收机制确保内存的有效管理,同时也能通过JIT编译器优化来提升运行时性能。 标准库丰富:Java拥有庞大的类库,如Java SE(Java Standard Edition)包含基础API,用于开发通用应用程序;Java EE(Java Enterprise Edition)提供企业级服务,如Web服务、EJB等;而Java ME(Java Micro Edition)则针对小型设备和嵌入式系统。 社区活跃:Java有着全球范围内庞大的开发者社区和开源项目,持续推动技术进步和创新。 多线程支持:Java内建对多线程编程的支持,使并发编程变得更加简单直接。 动态性:Java可以通过反射、注解等机制实现在运行时动态加载类和修改行为,增加了程序的灵活性。 综上所述,Java凭借其强大的特性和广泛的适用范围,在企业级应用、互联网服务、移动开发等领域均扮演着举足轻重的角色,是现代软件开发不可或缺的重要工具之一。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值