Java实现队列的两种方式
2022/3/1 20:22:04
本文主要是介绍Java实现队列的两种方式,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
Java实现循环队列
数组实现
public class Queue_<T> { // 循环队列的数组 private Object[] object; // 首指针 private int front; // 尾指针 private int rear; public Queue_() { object = new Object[20]; front = rear = 0; } // 从尾部向队列添加元素 public void enQueue(int value) { if (isFull()) { throw new OutOfMemoryError(); } else { object[rear] = value; rear = (rear + 1) % 20; } } // 从首部删除队列元素 public void deQueue() { if (isEmpty()) { throw new NullPointerException(); } else { front = (front + 1) % 20; } } // 返回队首元素 public T Front() { if (isEmpty()) return null; else return (T) object[front]; } // 返回队尾元素 public T Rear() { if (isEmpty()) return null; else return (T) object[(rear - 1 + 20) % 20]; } // 判断队列是否为空 public boolean isEmpty() { return (rear == front); } // 判断队列是否已满 public boolean isFull() { return (rear + 1) % 20 == front; } // 返回队列长度 public int size() { return (rear - front + 20) % 20; } }
Java实现链式对联
内部类实现
public class Queue_plus<T> { // 节点 private class queue<T> { Object object; queue next; } // 首指针 queue<T> front; // 尾指针 queue<T> rear; int size; public Queue_plus() { front = rear = null; } // 从队列尾部添加元素 public void enQueue(T t) { if (t == null) { throw new NullPointerException(); } if (front == null) { front = rear = new queue<T>(); front.object = t; front.next = null; } else { rear.next = new queue<T>(); rear = rear.next; rear.object = t; rear.next = null; } } // 从队列首部删除元素 public void deQueue() { if (!isEmpty()) front = front.next; else throw new NullPointerException(); } // 返回队首元素 public T Front() { return (T) front.object; } // 返回队尾元素 public T Rear() { return (T) rear.object; } // 判断队列是否为空 public boolean isEmpty() { if (front == null) { return true; } else return false; } // 返回队列长度 public int size() { return size; } }
不足之处望指正。
这篇关于Java实现队列的两种方式的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2025-01-01一个基于注解驱动的可视化的DDD架构-超越COLA的设计
- 2025-01-01PlantUML 时序图 基本例子
- 2025-01-01plantuml 信号时序图
- 2025-01-01聊聊springboot项目如何优雅进行数据校验
- 2024-12-31自由职业者效率提升指南:3个时间管理技巧搞定多个项目
- 2024-12-31适用于咨询行业的项目管理工具:提升跨团队协作和工作效率的最佳选择
- 2024-12-31高效协作的未来:2024年实时文档工具深度解析
- 2024-12-31商务谈判者的利器!哪 6 款办公软件能提升春节合作成功率?
- 2024-12-31小团队如何选择最实用的项目管理工具?高效协作与任务追踪指南
- 2024-12-31数据赋能,智慧养老:看板软件如何重塑养老服务生态