欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

java數據結構基礎:順序隊列和循環(huán)隊列

 更新時間:2021年08月01日 10:34:16   作者:去吧貓頭夜鷹  
下面小編就為大家分享一篇java隊列實現方法(順序隊列,循環(huán)隊列),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧

隊列:

隊列是一種受限制的線性表

只允許在表的一端進行插入,另一端進行刪除

插入的一端稱作隊尾,刪除的一端稱作隊頭

具有先進先出的特性

順序隊列:

隊列底層數據采用數組存儲

設置隊頭指針front指向隊頭元素前一個位置,初始值為-1

設置隊尾指針rear指向隊尾元素,初始值為-1

判滿:rear == maxSize - 1

判空:rear == front

代碼實現:

//順序隊列
public class ArrayQueue {
	private int maxSize;    //數組的最大容量
	private int front;        //隊頭指針
	private int rear;        //隊尾指針
	private int[] array;    //存放數據
	public ArrayQueue(int arrMaxSize) {
		maxSize = arrMaxSize;
		array = new int[maxSize];
		front = -1;        //指向隊頭的前一個位置
		rear = -1;        //指向隊尾
	}
	//判斷隊列是否滿
	public boolean isFull() {
		return rear == maxSize - 1;
	}
	//判斷隊列是否空
	public boolean isEmpty() {
		return rear == front;
	}
	//入隊
	public void addQueue(int n) {
		//判斷隊列是否滿
		if (isFull()) {
			System.out.println("隊列滿");
			return;
		}
		rear++;    //rear后移
		array[rear] = n;
	}
	//出隊
	public int getQueue() {
		//判斷隊列是否空
		if (isEmpty()) {
			throw new RuntimeException("隊列為空");
		}
		front++;    //front后移
		return array[front];
	}
	//取隊頭數據
	public int headQueue() {
		if (isEmpty()) {
			throw new RuntimeException("隊列為空");
		}
		return array[front + 1];
	}
	//輸出隊列所有數據
	public void showQueue() {
		//遍歷輸出
		if (isEmpty()) {
			System.out.println("隊列為空");
            return;
		}
		for (int i = 0; i < array.length; i++) {
			System.out.printf("array[%d] = %d\n", i, array[i]);
		}
	}
}

順序隊列存在假溢出現象,故使用循環(huán)隊列替代順序隊列

循環(huán)隊列:

隊列底層數據仍然采用數組存儲

為了便于判空和判滿,在數組中預留一個空間,認為只留下一個空間的時候隊列為滿

設置隊頭指針front指向隊頭元素,初始值為0

設置隊尾指針rear指向隊尾元素的后一個位置,初始值為0

判滿:(rear + 1) % maxSize == front

判空:rear == front

取得當前隊列有效數據個數:(rear + maxSize - front) % maxSize

代碼實現:

//循環(huán)隊列
public class CircleQueue {
	private int maxSize;    //數組的最大容量
	private int front;        //隊頭指針
	private int rear;        //隊尾指針
	private int[] array;    //存放數據
	public CircleQueue(int arrMaxSize) {
		maxSize = arrMaxSize;
		array = new int[maxSize];
		front = 0;        //指向隊頭的前一個位置
		rear = 0;        //指向隊尾
	}
	//判斷隊列是否滿
	public boolean isFull() {
		return (rear + 1) % maxSize == front;
	}
	//判斷隊列是否空
	public boolean isEmpty() {
		return rear == front;
	}
	//入隊
	public void addQueue(int n) {
		//判斷隊列是否滿
		if (isFull()) {
			System.out.println("隊列滿");
			return;
		}
		array[rear] = n;
		rear = (rear + 1) % maxSize;
	}
	//出隊
	public int getQueue() {
		//判斷隊列是否空
		if (isEmpty()) {
			throw new RuntimeException("隊列為空");
		}
		//保存front對應的值
		int value = array[front];
		front = (front + 1) % maxSize;
		return value;
	}
	//取隊頭數據
	public int headQueue() {
		if (isEmpty()) {
			throw new RuntimeException("隊列為空");
		}
		return array[front];
	}
	//獲取當前隊列有效數據個數
	public int size() {
		return (rear + maxSize - front) % maxSize;
	}
	//輸出隊列所有數據
	public void showQueue() {
		//遍歷輸出
		if (isEmpty()) {
			System.out.println("隊列為空");
            return;
		}
		//從front開始遍歷
		for (int i = front; i < front + size(); i++) {
			System.out.printf("array[%d] = %d\n", i % maxSize, array[i % maxSize]);
		}
	}
}

總結

本篇文章就到這里了,希望能給你帶來幫助,也希望您能夠多多關注腳本之家的更多內容!

相關文章

  • JAVA 枚舉相關知識匯總

    JAVA 枚舉相關知識匯總

    這篇文章主要介紹了JAVA 枚舉相關知識,文中講解的非常詳細,代碼幫助大家更好的參考和學習,感興趣的朋友可以了解下
    2020-06-06
  • Struts中action線程安全問題解析

    Struts中action線程安全問題解析

    這篇文章主要介紹了Struts中action線程安全問題解析,涉及實例代碼,還是挺不錯的,具有一定參考價值,需要的朋友可以了解下。
    2017-10-10
  • 【MyBatis源碼全面解析】MyBatis一二級緩存介紹

    【MyBatis源碼全面解析】MyBatis一二級緩存介紹

    下面小編就為大家?guī)硪黄綧yBatis源碼全面解析】MyBatis一二級緩存介紹。小編覺得挺不錯的,現在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-06-06
  • 詳解SpringBoot健康檢查的實現原理

    詳解SpringBoot健康檢查的實現原理

    這篇文章主要介紹了詳解SpringBoot健康檢查的實現原理,幫助大家更好的理解和學習使用SpringBoot框架,感興趣的朋友可以了解下
    2021-03-03
  • Java獲取漢字對應的拼音(全拼或首字母)

    Java獲取漢字對應的拼音(全拼或首字母)

    這篇文章主要介紹了Java如何獲取漢字對應的拼音(全拼或首字母),文中實現的方法是引用了pinyin4j-2.5.0.jar,然后給出了完整的示例代碼,有需要的朋友可以參考借鑒,下面來一起看看吧。
    2017-01-01
  • 總結java多線程之互斥與同步解決方案

    總結java多線程之互斥與同步解決方案

    文中總結了線程互斥與同步,synchronized使用細節(jié)及原理,Reentrylock使用細節(jié)等知識,對解決Java多線程互斥與同步等問題很有效,,需要的朋友可以參考下
    2021-05-05
  • Spring Boot利用Thymeleaf發(fā)送Email的方法教程

    Spring Boot利用Thymeleaf發(fā)送Email的方法教程

    spring Boot默認就是使用thymeleaf模板引擎的,下面這篇文章主要給大家介紹了關于在Spring Boot中利用Thymeleaf發(fā)送Email的方法教程,文中通過示例代碼介紹的非常詳細,對大家具有一定的參考學習價值,需要的朋友們下面來一起看看吧。
    2017-08-08
  • Java實戰(zhàn)之客戶信息管理系統

    Java實戰(zhàn)之客戶信息管理系統

    這篇文章主要介紹了Java實戰(zhàn)之客戶信息管理系統,文中有非常詳細的代碼示例,對正在學習java的小伙伴們有非常好的幫助,需要的朋友可以參考下
    2021-04-04
  • IDEA?Eval?Reset?使用方法匯總

    IDEA?Eval?Reset?使用方法匯總

    本文給大家介紹了IDEA?Eval?Reset?使用方法,安裝插件包括離線安裝方式和在線安裝方式,本文給大家介紹的非常詳細,感興趣的朋友跟隨小編一起看看吧
    2023-10-10
  • Java 中利用泛型和反射機制抽象DAO的實例

    Java 中利用泛型和反射機制抽象DAO的實例

    這篇文章主要介紹了Java 中利用泛型和反射機制抽象DAO的實例的相關資料,需要的朋友可以參考下
    2017-07-07

最新評論