亚洲免费在线视频-亚洲啊v-久久免费精品视频-国产精品va-看片地址-成人在线视频网

您的位置:首頁技術文章
文章詳情頁

Java實現隊列的三種方法集合

瀏覽:26日期:2022-08-24 14:54:57

數組實現隊列

//數組實現隊列class queue{ int[] a = new int[5]; int i = 0; //入隊操作 public void in(int m) { a[i++] = m; }// 出隊列操作 取出最前面的值 通過循環遍歷把所有的數據向前一位 public int out() { int index = 0; int temp = a[0]; for(int j = 0;j < i;j++) { a[j] = a[j + 1]; } return temp; } }

ArrayList實現隊列

//集合實現隊列class queue{ List<Integer> list = new ArrayList<Integer>(); int index = 0; public void in(int n) { list.add(n); index++; } //出隊列操作 //出隊 public int out(){ if(!list.isEmpty()){ index--; return list.remove(0); } return -1; } }

兩個堆棧實現隊列

//兩個堆棧實現一個隊列class queue3 { Stack<Integer> stackA = new Stack<Integer>(); Stack<Integer> stackB = new Stack<Integer>(); //入隊 public void in(int n) { stackA.push(n); } //出隊 我們把A里面的元素遍歷拿出放入B中 再拿出B中的第一個元素 public int out() { //判斷b棧有沒有元素 有返回false 無返回真 if(stackB.isEmpty()) { while(!stackA.isEmpty()) { stackB.push(stackA.pop()); } } return stackB.pop(); }}

補充知識:java使用鏈表實現隊列

隊列使用Java進行鏈表實現,在網上找到了一張圖,很好,借鑒一下

Java實現隊列的三種方法集合

設置兩個結點node,front指向隊首元素,rear指向隊尾;

上代碼:

public class LinkedQueue { Node front;//隊頭指針,指向隊頭節點 Node rail;//隊尾指針,指向隊尾節點 int size = 0;//記錄隊列長度 //構造函數 public LinkedQueue() { front = rail = null; } public boolean isEmpty() { return size == 0 ? true : false; } //添加元素 public boolean addQueue(Object ele) { if (size == 0) { front = new Node(null, ele); rail = front; size++; return true; } Node s = new Node(null, ele); //這塊有個主意的地方,一旦rail設置了next屬性,因為front節點與rail節點指向了同一個node節點,持有同一個結點的一個引用,因此front節點next屬性也被填充 rail.setNext(s); rail = s; size++; return true; } /** * 刪除元素,出隊列 * @return */ public boolean deleteQueue() { if (isEmpty()) { System.out.println('當前隊列為空'); return false; } front = front.next; size--; return true; } public static void main(String[] args) { LinkedQueue queue = new LinkedQueue(); queue.addQueue(1); queue.addQueue(2); queue.addQueue(3); queue.deleteQueue(); } } /** * 首先鏈表底層是一個個結點 */class Node { Node next; Object element; public Node(Node next, Object element) { this.next = next; this.element = element; } public Node getNext() { return next; } public void setNext(Node next) { this.next = next; } public Object getElement() { return element; } public void setElement(Object element) { this.element = element; } }

以上這篇Java實現隊列的三種方法集合就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: Java
相關文章:
主站蜘蛛池模板: 中文字幕在线观看一区二区 | 91精品国产高清久久久久久io | 成人18免费网 | 91精品久久久久久久久网影视 | 99视频精品免费99在线 | 美国一级毛片在线 | 国产成人啪一区二区 | 三级网站大全 | 亚洲色视频在线播放网站 | 国产在线视频自拍 | 在线国产一区二区三区 | 成人的天堂 | 精品400部自拍视频在线播放 | 中文字幕福利片 | 日韩a毛片免费全部播放完整 | 殴美一级视频 | 玖玖色视频 | 亚洲国产天堂久久综合网站 | 国产一区二区三区四区在线观看 | 久久福利网站 | 欧美激情一区二区亚洲专区 | 成人国产精品久久久免费 | 就草草在线观看视频 | 国产性大片黄在线观看在线放 | 毛片免费观看成人 | 成人在线免费 | 国产男女免费完整视频 | 精品欧美一区二区三区四区 | 国产精品区一区二区免费 | 成人精品一区二区不卡视频 | 三级黄色免费网站 | 福利一二三区 | 日韩 亚洲 制服 欧美 综合 | 日本理论片免费高清影视在线观看 | 在线视免费频观看韩国aaa | 成人网在线免费观看 | 久久综合亚洲一区二区三区 | 在线成人a毛片免费播放 | 久久精品国产亚洲a | 亚洲欧美偷拍自拍 | 中文字幕日本一区波多野不卡 |