java編程隊列數(shù)據(jù)結(jié)構(gòu)代碼示例
隊列是一種特殊的線性表,只允許在表的前端進(jìn)行刪除,在表的后端進(jìn)行插入,表的前端稱為(front)隊頭,表的后端稱為(rear)隊尾。
所以隊列跟生活的場景很是相似,在電影院買電影票,人們排成一排,第一個人進(jìn)入隊尾最先到達(dá)隊頭后買票進(jìn)入影院,后面排隊的人按照排隊的次序買到票后進(jìn)入影院。
所以 隊列是一種先進(jìn)先出的數(shù)據(jù)結(jié)構(gòu)(FIFO)。
編程實現(xiàn)對循環(huán)鏈隊列的入隊和出隊操作。
⑴根據(jù)輸入的隊列長度n和各元素值建立一個帶頭結(jié)點的循環(huán)鏈表表示的隊列(循環(huán)鏈隊列),并且只設(shè)一個尾指針來指向尾結(jié)點,然后輸出隊列中各元素值。
⑵將數(shù)據(jù)元素e入隊,并輸出入隊后的隊列中各元素值。
⑶將循環(huán)鏈隊列的隊首元素出隊,并輸出出隊元素的值和出隊后隊列中各元素值。
當(dāng)隊列的插入數(shù)據(jù)時,Rear箭頭一直往上走,插入到表的最大下標(biāo)的位置后停止。在移除數(shù)據(jù)的時候,front箭頭也會一直往上走。
這可能跟現(xiàn)實中的人們在電影院買電影票的情況有點不符合,一般是買完票,人就往前走,繼續(xù)買票,隊伍總是向前移動的。
在計算機(jī)中,隊列每刪除一個數(shù)據(jù)項后,其他數(shù)據(jù)也可以繼續(xù)往移動,但如此一來,處理很大的數(shù)據(jù)的時候,這樣做的效率很低下,因為每次刪除一個數(shù)據(jù)就要將剩余的所有數(shù)據(jù)往前移動。
在刪除數(shù)據(jù)的時候,隊頭(Front)前面的位置就會留空,但由于隊尾(Rear)和隊頭(Front)這兩個箭頭都一直往上走,所以沒能繼續(xù)利用到前面空單元的存儲空間。
為了避免隊列不滿卻不能繼續(xù)插入新數(shù)據(jù)的情況,解決隊列能循環(huán)利用的方法就是,當(dāng)Rear箭頭和Front箭頭到達(dá)最大下標(biāo)的位置后,重新將它的位置移動到, 表的最初始的位置。
這個就是------循環(huán)隊列:
package DataStructure; /** * Created by Hubbert on 2017/11/11. */ public class Queue { private int [] arr ; private int front ; //隊頭指針 private int rear ; //隊尾指針 private int nItems ;//隊列中的個數(shù) private int maxSize;//隊列長度 //使用構(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);//判斷隊列是否已滿 } public boolean isEmpty(){ return (nItems == 0);//判斷隊列是否為空 } //插入 public void insert( int number ){ if(!isFull()){ //處理循環(huán)隊列 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)隊列 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("-----------先刪除隊列中前兩個數(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ù)使用隊列------------"); System.out.println("Front--->Rear:"); queue.insert(1); queue.insert(2); while (!queue.isEmpty()){ System.out.print(queue.remove() + " "); } } }
結(jié)果如下:
總結(jié)
以上就是本文關(guān)于java編程隊列數(shù)據(jù)結(jié)構(gòu)代碼示例的全部內(nèi)容,希望對大家有所幫助。感興趣的朋友可以繼續(xù)參閱本站:
java編程實現(xiàn)優(yōu)先隊列的二叉堆代碼分享
Java編程用兩個棧實現(xiàn)隊列代碼分享
如有不足之處,歡迎留言指出。期待您的寶貴意見。
欄 目:Java編程
下一篇:Java編程小實例—數(shù)字時鐘的實現(xiàn)代碼示例
本文標(biāo)題:java編程隊列數(shù)據(jù)結(jié)構(gòu)代碼示例
本文地址:http://mengdiqiu.com.cn/a1/Javabiancheng/8428.html
您可能感興趣的文章
- 01-10Java咖啡館(1)——嘆咖啡
- 01-10Java Socket編程(三) 服務(wù)器Sockets
- 01-10Java進(jìn)階:Struts多模塊的技巧
- 01-10Java Socket編程(一) Socket傳輸模式
- 01-10Java Socket編程(二) Java面向連接的類
- 01-10Java運行時多態(tài)性的實現(xiàn)
- 01-10Java經(jīng)驗點滴:處理沒有被捕獲的異常
- 01-10Java Socket編程(四) 重復(fù)和并發(fā)服務(wù)器
- 01-10Java中的浮點數(shù)分析
- 01-10面向?qū)ο缶幊?Java中的抽象數(shù)據(jù)類型


閱讀排行
本欄相關(guān)
- 01-10Java咖啡館(1)——嘆咖啡
- 01-10JVM的垃圾回收機(jī)制詳解和調(diào)優(yōu)
- 01-10Java Socket編程(三) 服務(wù)器Sockets
- 01-10Java進(jìn)階:Struts多模塊的技巧
- 01-10J2SE 1.5版本的新特性一覽
- 01-10Java Socket編程(一) Socket傳輸模式
- 01-10Java運行時多態(tài)性的實現(xiàn)
- 01-10Java Socket編程(二) Java面向連接的類
- 01-10Java Socket編程(四) 重復(fù)和并發(fā)服務(wù)
- 01-10Java經(jīng)驗點滴:處理沒有被捕獲的異常
隨機(jī)閱讀
- 01-10使用C語言求解撲克牌的順子及n個骰子
- 01-10delphi制作wav文件的方法
- 01-10C#中split用法實例總結(jié)
- 08-05織夢dedecms什么時候用欄目交叉功能?
- 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
- 01-10SublimeText編譯C開發(fā)環(huán)境設(shè)置
- 04-02jquery與jsp,用jquery
- 08-05dedecms(織夢)副欄目數(shù)量限制代碼修改
- 01-11ajax實現(xiàn)頁面的局部加載
- 08-05DEDE織夢data目錄下的sessions文件夾有什