Java中怎么定义和使用循环队列,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。一、概述:1、原理:与普通队列的区别在于循环队列添加数据时,如果其有效数据end == max
Java中怎么定义和使用循环队列,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。
一、概述:
1、原理:
与普通队列的区别在于循环队列添加数据时,如果其有效数据end == maxSize - 1(最大空间)的话,end指针又移动到-1的位置
删除数据时,如果head== maxSize时 head指针移动到0的位置
2、示例图:
二、实现代码:
package com.java.queue;public class CycleQueue { private long[] arr; private int maxSize;// 最大空间 private int len;// 有效长度 private int head;// 队头 private int end;// 队尾 public CycleQueue(int size) { this.maxSize = size; this.arr = new long[maxSize]; this.len = 0; this.head = 0; this.end = -1; } public void insert(long value) { //如果满了,为什么是maxSize - 1 ,因为从-1开始 if (end == maxSize - 1) { end = -1; } arr[++end] = value; len++; } public long remove() { long result = arr[head++]; if (head == maxSize) { head = 0; } len--; return result; } public boolean isEmpty() { return (len == 0); } public boolean isFull() { return (len == maxSize); } public int size() { return len; } public static void main(String[] args) { CycleQueue queue = new CycleQueue(50); queue.insert(22); queue.insert(33); queue.insert(44); queue.insert(534); queue.insert(21); queue.insert(55); System.out.println("编程网测试结果:"); while (!queue.isEmpty()) { System.out.print(queue.remove() + " "); } System.out.println(); queue.insert(33); queue.insert(13); queue.insert(23); while (!queue.isEmpty()) { System.out.print(queue.remove() + " "); } }}
运行结果:
关于Java中怎么定义和使用循环队列问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注编程网精选频道了解更多相关知识。
--结束END--
本文标题: Java中怎么定义和使用循环队列
本文链接: https://lsjlt.com/news/222177.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
2024-05-24
2024-05-24
2024-05-24
2024-05-24
2024-05-24
2024-05-24
2024-05-24
2024-05-24
2024-05-24
2024-05-24
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0