java編程隊(duì)列數(shù)據(jù)結(jié)構(gòu)代碼示例
隊(duì)列是一種特殊的線性表,只允許在表的前端進(jìn)行刪除,在表的后端進(jìn)行插入,表的前端稱為(front)隊(duì)頭,表的后端稱為(rear)隊(duì)尾。
所以隊(duì)列跟生活的場(chǎng)景很是相似,在電影院買電影票,人們排成一排,第一個(gè)人進(jìn)入隊(duì)尾最先到達(dá)隊(duì)頭后買票進(jìn)入影院,后面排隊(duì)的人按照排隊(duì)的次序買到票后進(jìn)入影院。
所以 隊(duì)列是一種先進(jìn)先出的數(shù)據(jù)結(jié)構(gòu)(FIFO)。
編程實(shí)現(xiàn)對(duì)循環(huán)鏈隊(duì)列的入隊(duì)和出隊(duì)操作。
⑴根據(jù)輸入的隊(duì)列長(zhǎng)度n和各元素值建立一個(gè)帶頭結(jié)點(diǎn)的循環(huán)鏈表表示的隊(duì)列(循環(huán)鏈隊(duì)列),并且只設(shè)一個(gè)尾指針來(lái)指向尾結(jié)點(diǎn),然后輸出隊(duì)列中各元素值。
⑵將數(shù)據(jù)元素e入隊(duì),并輸出入隊(duì)后的隊(duì)列中各元素值。
⑶將循環(huán)鏈隊(duì)列的隊(duì)首元素出隊(duì),并輸出出隊(duì)元素的值和出隊(duì)后隊(duì)列中各元素值。
當(dāng)隊(duì)列的插入數(shù)據(jù)時(shí),Rear箭頭一直往上走,插入到表的最大下標(biāo)的位置后停止。在移除數(shù)據(jù)的時(shí)候,front箭頭也會(huì)一直往上走。
這可能跟現(xiàn)實(shí)中的人們?cè)陔娪霸嘿I電影票的情況有點(diǎn)不符合,一般是買完票,人就往前走,繼續(xù)買票,隊(duì)伍總是向前移動(dòng)的。
在計(jì)算機(jī)中,隊(duì)列每刪除一個(gè)數(shù)據(jù)項(xiàng)后,其他數(shù)據(jù)也可以繼續(xù)往移動(dòng),但如此一來(lái),處理很大的數(shù)據(jù)的時(shí)候,這樣做的效率很低下,因?yàn)槊看蝿h除一個(gè)數(shù)據(jù)就要將剩余的所有數(shù)據(jù)往前移動(dòng)。
在刪除數(shù)據(jù)的時(shí)候,隊(duì)頭(Front)前面的位置就會(huì)留空,但由于隊(duì)尾(Rear)和隊(duì)頭(Front)這兩個(gè)箭頭都一直往上走,所以沒能繼續(xù)利用到前面空單元的存儲(chǔ)空間。
為了避免隊(duì)列不滿卻不能繼續(xù)插入新數(shù)據(jù)的情況,解決隊(duì)列能循環(huán)利用的方法就是,當(dāng)Rear箭頭和Front箭頭到達(dá)最大下標(biāo)的位置后,重新將它的位置移動(dòng)到, 表的最初始的位置。
這個(gè)就是------循環(huán)隊(duì)列:
package DataStructure; /** * Created by Hubbert on 2017/11/11. */ public class Queue { private int [] arr ; private int front ; //隊(duì)頭指針 private int rear ; //隊(duì)尾指針 private int nItems ;//隊(duì)列中的個(gè)數(shù) private int maxSize;//隊(duì)列長(zhǎng)度 //使用構(gòu)造函數(shù)進(jìn)行初始化 public Queue( int maxSize ){ this.maxSize = maxSize ; this.arr = new int [this.maxSize]; this.nItems = 0 ; this.front = 0; this.rear = -1 ; } public boolean isFull(){ return (nItems == maxSize);//判斷隊(duì)列是否已滿 } public boolean isEmpty(){ return (nItems == 0);//判斷隊(duì)列是否為空 } //插入 public void insert( int number ){ if(!isFull()){ //處理循環(huán)隊(duì)列 if( rear == (maxSize -1)){ rear = -1; } arr[++rear] = number ; nItems++; }else{ System.out.println("The Queue is full!!"); } } //刪除 public int remove(){ if(!isEmpty()){ //處理循環(huán)隊(duì)列 if( front == maxSize ){ front = 0; } nItems--; return arr[front++]; } else { System.err.println ("The Queue is Empty!!"); return -1; } } public static void main(String [] args){ Queue queue = new Queue(5); queue.insert(22); queue.insert(33); queue.insert(44); queue.insert(55); queue.insert(66); System.out.println("-----------先刪除隊(duì)列中前兩個(gè)數(shù)據(jù)------------"); System.out.println("Front--->Rear:"); for( int i =0 ; i < 2 ; i++ ){ System.out.print(queue.remove() + " "); } System.out.println(""); System.out.println("-----------繼續(xù)使用隊(duì)列------------"); System.out.println("Front--->Rear:"); queue.insert(1); queue.insert(2); while (!queue.isEmpty()){ System.out.print(queue.remove() + " "); } } }
結(jié)果如下:
總結(jié)
以上就是本文關(guān)于java編程隊(duì)列數(shù)據(jù)結(jié)構(gòu)代碼示例的全部?jī)?nèi)容,希望對(duì)大家有所幫助。感興趣的朋友可以繼續(xù)參閱本站:
java編程實(shí)現(xiàn)優(yōu)先隊(duì)列的二叉堆代碼分享
Java編程用兩個(gè)棧實(shí)現(xiàn)隊(duì)列代碼分享
如有不足之處,歡迎留言指出。期待您的寶貴意見。
- java實(shí)現(xiàn)隊(duì)列queue數(shù)據(jù)結(jié)構(gòu)詳解
- Java深入了解數(shù)據(jù)結(jié)構(gòu)之棧與隊(duì)列的詳解
- Java隊(duì)列數(shù)據(jù)結(jié)構(gòu)的實(shí)現(xiàn)
- Java數(shù)據(jù)結(jié)構(gòu)與算法之循環(huán)隊(duì)列的實(shí)現(xiàn)
- Java數(shù)據(jù)結(jié)構(gòu)與算法之稀疏數(shù)組與隊(duì)列深入理解
- java數(shù)據(jù)結(jié)構(gòu)-堆實(shí)現(xiàn)優(yōu)先隊(duì)列
- Java數(shù)據(jù)結(jié)構(gòu)之鏈表、棧、隊(duì)列、樹的實(shí)現(xiàn)方法示例
- java實(shí)現(xiàn)隊(duì)列數(shù)據(jù)結(jié)構(gòu)代碼詳解
- Java?數(shù)據(jù)結(jié)構(gòu)與算法系列精講之隊(duì)列
相關(guān)文章
Mybatis Plus LambdaQueryWrapper的具體用法
Mybatis Plus 在其基礎(chǔ)上擴(kuò)展了 LambdaQueryWrapper,LambdaQueryWrapper 提供了更加簡(jiǎn)便的查詢語(yǔ)法,同時(shí)也避免了SQL注入的風(fēng)險(xiǎn),感興趣的可以了解一下2023-11-11Java中的while循環(huán)語(yǔ)句詳細(xì)講解
這篇文章主要給大家介紹了關(guān)于Java中while循環(huán)語(yǔ)句的相關(guān)資料,while循環(huán)是一種在編程中常見的控制流語(yǔ)句,它允許代碼在特定條件下(通常是一個(gè)布爾表達(dá)式)重復(fù)執(zhí)行一段代碼,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-03-03關(guān)于spring項(xiàng)目中無(wú)法加載resources下文件問(wèn)題及解決方法
在學(xué)習(xí)Spring過(guò)程中,TestContext框架試圖檢測(cè)一個(gè)默認(rèn)的XML資源位置,再resources下創(chuàng)建了一個(gè)com.example的文件夾,執(zhí)行時(shí),報(bào)錯(cuò),本文給大家介紹spring項(xiàng)目中無(wú)法加載resources下文件,感興趣的朋友跟隨小編一起看看吧2023-10-10java網(wǎng)絡(luò)編程學(xué)習(xí)java聊天程序代碼分享
java聊天程序代碼分享,大家參考使用吧2013-12-12Spring boot基于JPA訪問(wèn)MySQL數(shù)據(jù)庫(kù)的實(shí)現(xiàn)
本文主要介紹了Spring boot基于JPA訪問(wèn)MySQL數(shù)據(jù)庫(kù)的實(shí)現(xiàn),Spring boot結(jié)合Jpa 能夠簡(jiǎn)化創(chuàng)建 JPA 數(shù)據(jù)訪問(wèn)層和跨存儲(chǔ)的持久層功能,用戶的持久層Dao接口只需要繼承定義好的接口,感興趣的可以了解一下2021-06-06Java?C++題解leetcode字符串輪轉(zhuǎn)KMP算法詳解
這篇文章主要為大家介紹了Java?C++題解leetcode字符串輪轉(zhuǎn)KMP算法詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-09-09通過(guò)springboot+mybatis+druid配置動(dòng)態(tài)數(shù)據(jù)源
這篇文章主要介紹了通過(guò)springboot+mybatis+druid配置動(dòng)態(tài)數(shù)據(jù)源,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,,需要的朋友可以參考下2019-06-06SpringBoot中整合Ehcache實(shí)現(xiàn)熱點(diǎn)數(shù)據(jù)緩存的詳細(xì)過(guò)程
這篇文章主要介紹了SpringBoot中整合Ehcache實(shí)現(xiàn)熱點(diǎn)數(shù)據(jù)緩存,SpringBoot 中使用 Ehcache 比較簡(jiǎn)單,只需要簡(jiǎn)單配置,說(shuō)白了還是 Spring Cache 的用法,合理使用緩存機(jī)制,可以很好地提高項(xiàng)目的響應(yīng)速度,需要的朋友可以參考下2023-04-04通過(guò)@Resource注解實(shí)現(xiàn)屬性裝配代碼詳解
這篇文章主要介紹了通過(guò)@Resource注解實(shí)現(xiàn)屬性裝配代碼詳解,具有一定借鑒價(jià)值,需要的朋友可以參考下2018-01-01