java數(shù)據(jù)結(jié)構(gòu)基礎(chǔ):順序隊(duì)列和循環(huán)隊(duì)列
隊(duì)列:
隊(duì)列是一種受限制的線性表
只允許在表的一端進(jìn)行插入,另一端進(jìn)行刪除
插入的一端稱作隊(duì)尾,刪除的一端稱作隊(duì)頭
具有先進(jìn)先出的特性
順序隊(duì)列:
隊(duì)列底層數(shù)據(jù)采用數(shù)組存儲
設(shè)置隊(duì)頭指針front指向隊(duì)頭元素前一個位置,初始值為-1
設(shè)置隊(duì)尾指針rear指向隊(duì)尾元素,初始值為-1
判滿:rear == maxSize - 1
判空:rear == front
代碼實(shí)現(xiàn):
//順序隊(duì)列
public class ArrayQueue {
private int maxSize; //數(shù)組的最大容量
private int front; //隊(duì)頭指針
private int rear; //隊(duì)尾指針
private int[] array; //存放數(shù)據(jù)
public ArrayQueue(int arrMaxSize) {
maxSize = arrMaxSize;
array = new int[maxSize];
front = -1; //指向隊(duì)頭的前一個位置
rear = -1; //指向隊(duì)尾
}
//判斷隊(duì)列是否滿
public boolean isFull() {
return rear == maxSize - 1;
}
//判斷隊(duì)列是否空
public boolean isEmpty() {
return rear == front;
}
//入隊(duì)
public void addQueue(int n) {
//判斷隊(duì)列是否滿
if (isFull()) {
System.out.println("隊(duì)列滿");
return;
}
rear++; //rear后移
array[rear] = n;
}
//出隊(duì)
public int getQueue() {
//判斷隊(duì)列是否空
if (isEmpty()) {
throw new RuntimeException("隊(duì)列為空");
}
front++; //front后移
return array[front];
}
//取隊(duì)頭數(shù)據(jù)
public int headQueue() {
if (isEmpty()) {
throw new RuntimeException("隊(duì)列為空");
}
return array[front + 1];
}
//輸出隊(duì)列所有數(shù)據(jù)
public void showQueue() {
//遍歷輸出
if (isEmpty()) {
System.out.println("隊(duì)列為空");
return;
}
for (int i = 0; i < array.length; i++) {
System.out.printf("array[%d] = %d\n", i, array[i]);
}
}
}
順序隊(duì)列存在假溢出現(xiàn)象,故使用循環(huán)隊(duì)列替代順序隊(duì)列
循環(huán)隊(duì)列:
隊(duì)列底層數(shù)據(jù)仍然采用數(shù)組存儲
為了便于判空和判滿,在數(shù)組中預(yù)留一個空間,認(rèn)為只留下一個空間的時候隊(duì)列為滿
設(shè)置隊(duì)頭指針front指向隊(duì)頭元素,初始值為0
設(shè)置隊(duì)尾指針rear指向隊(duì)尾元素的后一個位置,初始值為0
判滿:(rear + 1) % maxSize == front
判空:rear == front
取得當(dāng)前隊(duì)列有效數(shù)據(jù)個數(shù):(rear + maxSize - front) % maxSize
代碼實(shí)現(xiàn):
//循環(huán)隊(duì)列
public class CircleQueue {
private int maxSize; //數(shù)組的最大容量
private int front; //隊(duì)頭指針
private int rear; //隊(duì)尾指針
private int[] array; //存放數(shù)據(jù)
public CircleQueue(int arrMaxSize) {
maxSize = arrMaxSize;
array = new int[maxSize];
front = 0; //指向隊(duì)頭的前一個位置
rear = 0; //指向隊(duì)尾
}
//判斷隊(duì)列是否滿
public boolean isFull() {
return (rear + 1) % maxSize == front;
}
//判斷隊(duì)列是否空
public boolean isEmpty() {
return rear == front;
}
//入隊(duì)
public void addQueue(int n) {
//判斷隊(duì)列是否滿
if (isFull()) {
System.out.println("隊(duì)列滿");
return;
}
array[rear] = n;
rear = (rear + 1) % maxSize;
}
//出隊(duì)
public int getQueue() {
//判斷隊(duì)列是否空
if (isEmpty()) {
throw new RuntimeException("隊(duì)列為空");
}
//保存front對應(yīng)的值
int value = array[front];
front = (front + 1) % maxSize;
return value;
}
//取隊(duì)頭數(shù)據(jù)
public int headQueue() {
if (isEmpty()) {
throw new RuntimeException("隊(duì)列為空");
}
return array[front];
}
//獲取當(dāng)前隊(duì)列有效數(shù)據(jù)個數(shù)
public int size() {
return (rear + maxSize - front) % maxSize;
}
//輸出隊(duì)列所有數(shù)據(jù)
public void showQueue() {
//遍歷輸出
if (isEmpty()) {
System.out.println("隊(duì)列為空");
return;
}
//從front開始遍歷
for (int i = front; i < front + size(); i++) {
System.out.printf("array[%d] = %d\n", i % maxSize, array[i % maxSize]);
}
}
}
總結(jié)
本篇文章就到這里了,希望能給你帶來幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!
相關(guān)文章
SpringBoot整合MongoDB實(shí)現(xiàn)文檔存儲功能
MongoDB是可以應(yīng)用于各種規(guī)模的企業(yè)、各個行業(yè)以及各類應(yīng)用程序的開源數(shù)據(jù)庫,本文將結(jié)合MongoDB和SpringBoot實(shí)現(xiàn)文檔存儲功能,需要的可以參考下2024-12-12
淺析Spring?Cloud?Gateway中的令牌桶限流算法
這篇文章主要為大家淺析了Spring?Cloud?Gateway中的令牌桶限流算法原理,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步2022-02-02
java如何使用正則表達(dá)式限制特殊字符的個數(shù)
這篇文章主要介紹了java如何使用正則表達(dá)式限制特殊字符的個數(shù),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-11-11
基于java web獲取網(wǎng)頁訪問次數(shù)代碼實(shí)例
這篇文章主要介紹了基于java web獲取網(wǎng)頁訪問次數(shù)代碼實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-02-02
mybatis-plus enum實(shí)現(xiàn)枚舉類型自動轉(zhuǎn)換
本文主要介紹了mybatis-plus enum實(shí)現(xiàn)枚舉類型自動轉(zhuǎn)換,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2024-07-07
java基礎(chǔ)詳解之?dāng)?shù)據(jù)類型知識點(diǎn)總結(jié)
這篇文章主要介紹了java基礎(chǔ)詳解之?dāng)?shù)據(jù)類型知識點(diǎn)總結(jié),文中有非常詳細(xì)的代碼示例,對正在學(xué)習(xí)java基礎(chǔ)的小伙伴們有很大的幫助,需要的朋友可以參考下2021-04-04
Mybatis使用useGeneratedKeys獲取自增主鍵的方法
這篇文章主要給大家介紹了關(guān)于Mybatis使用useGeneratedKeys獲取自增主鍵的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用Mybatis具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2019-09-09
使用@CachePut?更新數(shù)據(jù)庫和更新緩存
這篇文章主要介紹了使用@CachePut?更新數(shù)據(jù)庫和更新緩存方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-12-12

