您好,登錄后才能下訂單哦!
本篇內容主要講解“Java集合框架之如何使用Stack Queue Deque”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“Java集合框架之如何使用Stack Queue Deque”吧!
1. Stack
1.1 介紹
1.2 常見方法
2. Queue
2.1 介紹
2.2 常見方法
3. Deque
3.1 介紹
3.2 常見方法
Stack 棧是 Vector 的一個子類,它實現了一個標準的后進先出的棧。它的底層是一個數組。
堆棧只定義了默認構造函數,用來創建一個空棧。堆棧除了包括由 Vector 定義的所有方法,也定義了自己的一些方法。
方法 | 描述 |
---|---|
E push(E item) | 壓棧 |
E pop() | 出棧 |
E peek() | 查看棧頂元素,不刪除 |
boolean empty() | 判斷棧是否為空 |
注意: 下面的示例都是一份代碼分開拿出來的,上下其實是有邏輯關系的
示例一: 用 Stack 構造一個元素為整形的棧
Stack<Integer> stack = new Stack<>();
示例二: 壓棧
stack.push(1); stack.push(2); stack.push(3); // 結果為:[1, 2, 3]
示例三: 查看棧頂元素不刪除
System.out.println(stack.peek()); System.out.println(stack); // 結果為:3 和 [1, 2, 3]
示例四: 出棧
System.out.println(stack.pop()); System.out.println(stack); // 結果為:3 和 [1, 2]
示例五: 判斷棧是否為空
System.out.println(stack.empty()); // 結果為:false
Queue 隊列是一種特殊的線性表,它只允許在表的前端進行刪除操作,而在表的后端進行插入操作。
LinkedList 類實現了 Queue 接口,因此我們可以把 LinkedList 當成 Queue 來用。
方法 | 描述 |
---|---|
boolean offer(E e) | 入隊列(出現錯誤返回特殊值) |
boolean add(E e) | 入隊列(出現錯誤拋異常) |
E poll() | 出隊列(出現錯誤返回特殊值) |
E remove() | 出隊列(出現錯誤拋異常) |
E peek() | 得到隊首元素,不刪除(出現錯誤返回特殊值) |
E element() | 得到隊首元素,不刪除(出現錯誤拋異常) |
boolean isEmpty() | 判斷隊列是否為空 |
注意: 接下來使用 LinkedList 演示隊列的使用方法,只要把握先進先出的原則就行。下面的示例都是一份代碼分開拿出來的,上下其實是有邏輯關系的
示例一: 使用 LinkedList 創建一個元素為整型的隊列
LinkedList<Integer> linkedList = new LinkedList<>();
示例二: 入隊列
linkedList.offer(1); linkedList.offer(2); linkedList.offer(3);
示例三: 出隊列
System.out.println(linkedList.poll()); // 結果為:1
示例四: 得到隊首元素,不刪除
System.out.println(linkedList.peek()); // 結果為:2
示例五: 判斷隊列是否為空
System.out.println(linkedList.isEmpty()); // 結果為:false
雙端隊列是指允許兩端都可以進行入隊和出隊操作的隊列。元素可以從隊頭出隊和入隊,也可以從隊尾出隊和入隊
LinkedList 類實現了 Deque 接口,因此我們可以把 LinkedList 當成 Deque 來用。
方法 | 描述 |
---|---|
boolean offerFirst(E e) | 從隊頭入隊 |
boolean offerLast(E e) | 從隊尾入隊 |
E pollFirst() | 從隊頭出隊 |
E pollLast() | 從隊尾出隊 |
E peekFirst() | 得到隊頭元素,不刪除 |
E peekLast() | 得到隊尾元素,不刪除 |
注意: 接下來使用 LinkedList 演示隊列的使用方法,只要把握先進先出的原則就行。下面的示例都是一份代碼分開拿出來的,上下其實是有邏輯關系的
示例一: 使用 LinkedList 創建一個元素為整型的隊列
LinkedList<Integer> linkedList = new LinkedList<>();
示例二: 從隊頭入隊
linkedList.offerFirst(1); linkedList.offerFirst(2); linkedList.offerFirst(3); // 隊列為:[3, 2, 1]
示例三: 從隊尾入隊
linkedList.offerLast(7); linkedList.offerLast(8); linkedList.offerLast(9); // 隊列為:[3, 2, 1, 7, 8, 9]
示例四: 從隊頭出隊
System.out.println(linkedList.pollFirst()); // 結果為:3
示例五: 從隊尾出隊
System.out.println(linkedList.pollLast()); // 結果為:9
示例六: 得到隊頭元素,不刪除
System.out.println(linkedList.peekFirst()); // 結果為:2
示例七: 得到隊頭元素,不刪除
System.out.println(linkedList.peekLast()); // 結果為:8
到此,相信大家對“Java集合框架之如何使用Stack Queue Deque”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。