Java用數(shù)組實(shí)現(xiàn)循環(huán)隊(duì)列的示例
復(fù)習(xí)了下數(shù)據(jù)結(jié)構(gòu),用Java的數(shù)組實(shí)現(xiàn)一下循環(huán)隊(duì)列。
隊(duì)列的類
//循環(huán)隊(duì)列
class CirQueue{
private int QueueSize;
private int front;
private int rear;
private int[] queueList ;
public CirQueue(int QueueSize){
this.QueueSize = QueueSize;
queueList = new int[QueueSize];
front = 0;
rear = 0;
}
//獲取隊(duì)列頭元素
public int getQueueElement(){
//如果隊(duì)列不為空,返回隊(duì)頭元素,否則拋出異常提示隊(duì)列為空
int element = -1;
if(!isEmpty()){
element = queueList[front];
return element;
}
else {
System.out.println("隊(duì)列為空");
return -1;
}
}
//出隊(duì)
public int deQueue(){
int element = -1;
if(!isEmpty()){
element = queueList[front];
front =(front+1)%QueueSize;
return element;
}
else {
System.out.println("隊(duì)列為空");
return -1;
}
}
//入隊(duì)
public void enQueue(int element){
//如果隊(duì)列未滿,添加元素到隊(duì)尾,否則提示隊(duì)列已滿
if(!isFull()){
queueList[rear] = element ;
rear = (rear+1)%QueueSize;
}
else {
System.out.println("隊(duì)列已滿");
}
}
//判斷隊(duì)列是否為空
public boolean isEmpty(){
boolean b = false;
if(rear == front)
b = true;
return b;
}
//判斷隊(duì)列是否已滿
public boolean isFull(){
boolean b = false;
if((rear+1)%QueueSize == front)
b = true;
return b;
}
}
創(chuàng)建對象并測試
package com.test;
import java.util.*;
public class StructTest {
/**
* @param args
*/
public static void main(String[] args) {
// TODO Auto-generated method stub
//新建并初始化存儲(chǔ)空間為3的循環(huán)隊(duì)列(方便判斷隊(duì)滿條件,浪費(fèi)一個(gè)數(shù)組空間)
CirQueue cirQueue = new CirQueue(4);
//入隊(duì)3個(gè)元素
cirQueue.enQueue(1);
cirQueue.enQueue(2);
cirQueue.enQueue(3);
//獲取隊(duì)頭元素,獲取 但不改變隊(duì)列
int temp = cirQueue.getQueueElement();
System.out.println(temp);
//出隊(duì) 獲取隊(duì)頭元素,并且隊(duì)頭指針往后移一位
temp = cirQueue.deQueue();
System.out.println(temp);
//再次獲取隊(duì)頭元素
temp = cirQueue.getQueueElement();
System.out.println(temp);
}
}
輸出:
1 1 2
以上這篇Java用數(shù)組實(shí)現(xiàn)循環(huán)隊(duì)列的示例就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Spring實(shí)戰(zhàn)之屬性覆蓋占位符配置器用法示例
這篇文章主要介紹了Spring實(shí)戰(zhàn)之屬性覆蓋占位符配置器用法,結(jié)合實(shí)例形式分析了Spring屬性覆蓋占位符配置器相關(guān)原理、配置與使用技巧,需要的朋友可以參考下2019-12-12
Spring4下validation數(shù)據(jù)校驗(yàn)無效(maven)的解決
這篇文章主要介紹了Spring4下validation數(shù)據(jù)校驗(yàn)無效(maven)的解決,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-06-06
關(guān)于java.io.EOFException產(chǎn)生的原因以及解決方案
文章總結(jié):EOFException異常通常發(fā)生在嘗試從空的ObjectInputStream對象中讀取數(shù)據(jù)時(shí),解決方法是在finally語句中添加判斷,確保objectInputStream不為空后再進(jìn)行關(guān)閉操作,在處理1.txt文件為空的情況時(shí),捕獲EOFException可以避免程序終止,并且不會(huì)拋出空指針異常2025-01-01
Java 中的HashMap詳解和使用示例_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
這篇文章主要介紹了Java 中的HashMap詳解和使用示例_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理,需要的朋友可以參考下2017-05-05
SpringBoot發(fā)送html郵箱驗(yàn)證碼功能
這篇文章主要介紹了SpringBoot發(fā)送html郵箱驗(yàn)證碼,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-12-12
IDEA Debug啟動(dòng)tomcat報(bào)60659端口占用錯(cuò)誤的解決
工作中將開發(fā)工具由Eclipse轉(zhuǎn)為IntelliJ IDEA,在使用過程中遇到許多問題,其中60659端口占用錯(cuò)誤對于不熟悉IDEA的開發(fā)者來說或許會(huì)比較頭痛,本文就來解決一下這個(gè)問題2018-11-11

