java使用数组实现循环队列

Posted CLAY&Loser

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了java使用数组实现循环队列相关的知识,希望对你有一定的参考价值。

package com.Alg;

import java.io.Serializable;
import java.util.Arrays;

/**
 * @ClassName: LoopQueue
 * @Description: 循环队列
 * @date 2014年1月20日 下午3:47:14
 */
public class Round_RobinQueue<T> implements Serializable 
	/**
	 * @Fields serialVersionUID : TODO
	 */
	private static final long serialVersionUID = 1L;

	private int DEFAULT_SIZE = 10;

	private int capacity;// 保存数组的长度

	private Object[] elementData;// 定义一个数组用于保存循环队列的元素

	private int front = 0;// 队头

	private int rear = 0;// 队尾

	// 以默认数组长度创建空循环队列
	public Round_RobinQueue() 
		capacity = DEFAULT_SIZE;
		elementData = new Object[capacity];
	

	// 以一个初始化元素来创建循环队列
	public Round_RobinQueue(T element) 
		this();
		elementData[0] = element;
		rear++;
	

	/**
	 * 以指定长度的数组来创建循环队列
	 * 
	 * @param element
	 *            指定循环队列中第一个元素
	 * @param initSize
	 *            指定循环队列底层数组的长度
	 */
	public Round_RobinQueue(T element, int initSize) 
		this.capacity = initSize;
		elementData = new Object[capacity];
		elementData[0] = element;
		rear++;
	

	// 获取循环队列的大小
	public int size() 
		if (isEmpty()) 
			return 0;
		
		return rear > front ? rear - front : capacity - (front - rear);
	

	// 插入队列
	public void add(T element) 
		if (rear == front && elementData[front] != null) 
			throw new IndexOutOfBoundsException("队列已满的异常");
		
		elementData[rear++] = element;
		// 如果rear已经到头,那就转头
		rear = rear == capacity ? 0 : rear;
	

	// 移除队列
	public T remove() 
		if (isEmpty()) 
			throw new IndexOutOfBoundsException("空队列异常");
		
		// 保留队列的rear端的元素的值
		T oldValue = (T) elementData[front];
		// 释放队列的rear端的元素
		elementData[front++] = null;
		// 如果front已经到头,那就转头
		front = front == capacity ? 0 : front;
		return oldValue;
	

	// 返回队列顶元素,但不删除队列顶元素
	public T element() 
		if (isEmpty()) 
			throw new IndexOutOfBoundsException("空队列异常");
		
		return (T) elementData[front];
	

	// 判断循环队列是否为空队列
	public boolean isEmpty() 
		// rear==front且rear处的元素为null
		return rear == front && elementData[rear] == null;
	

	// 清空循环队列
	public void clear() 
		// 将底层数组所有元素赋为null
		Arrays.fill(elementData, null);
		front = 0;
		rear = 0;
	

	public String toString() 
		if (isEmpty()) 
			return "[]";
		 else 
			// 如果front < rear,有效元素就是front到rear之间的元素
			if (front < rear) 
				StringBuilder sb = new StringBuilder("[");
				for (int i = front; i < rear; i++) 
					sb.append(elementData[i].toString() + ", ");
				
				int len = sb.length();
				return sb.delete(len - 2, len).append("]").toString();
			
			// 如果front >= rear,有效元素为front->capacity之间、0->front之间的
			else 
				StringBuilder sb = new StringBuilder("[");
				for (int i = front; i < capacity; i++) 
					sb.append(elementData[i].toString() + ", ");
				
				for (int i = 0; i < rear; i++) 
					sb.append(elementData[i].toString() + ", ");
				
				int len = sb.length();
				return sb.delete(len - 2, len).append("]").toString();
			
		
	

	public static void main(String[] args) 
		Round_RobinQueue<String> queue = new Round_RobinQueue<String>("aaaa", 3);
		// 添加两个元素
		queue.add("bbbb");
		queue.add("cccc");
		// 此时队列已满
		System.out.println(queue);
		// 删除一个元素后,队列可以再多加一个元素
		queue.remove();
		System.out.println("删除一个元素后的队列:" + queue);
		// 再次添加一个元素,此时队列又满
		queue.add("dddd");
		System.out.println(queue);
		System.out.println("队列满时的长度:" + queue.size());
		// 删除一个元素后,队列可以再多加一个元素
		queue.remove();
		// 再次加入一个元素,此时队列又满
		queue.add("eeee");
		System.out.println(queue);
	

以上是关于java使用数组实现循环队列的主要内容,如果未能解决你的问题,请参考以下文章

Java用数组实现循环队列

用java实现循环队列?

数据结构 - 数组模拟非循环和循环队列(Java实现)

go语言循环队列的实现

Java栈[数组,单链表],队列数组,链表和循环队列的实现

队列及循环队列(Java实现)