<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
1️⃣LinkedList 是 Java 集合框架中一個重要的實現,其底層採用的雙向連結串列結構,沒有初始化大小,就是一直在前面或者後面新增就好。由於基於連結串列實現,儲存元素過程中,無需像ArrayList那樣進行擴容。
2️⃣LinkedList 儲存元素的節點需要額外的空間儲存前驅和後繼的參照。
3️⃣LinkedList 在連結串列頭部和尾部插入效率比較高,但在指定位置進行插入時,效率一般。原因是,在指定位置插入需要定位到該位置處的節點,此操作的時間複雜度為 O(N)。
4️⃣和 ArrayList 一樣,LinkedList 也支援空值和重複值。LinkedList 也是非執行緒安全的集合類。
5️⃣由於 LinkedList 實現了 List 和 Deque 兩個介面,所以 LinkedList 方法分兩種,一種是 List 介面的方法,第二種是 Deque 介面的方法。
6️⃣由於 LinkedList 是一個實現了 Deque 的雙端佇列,所以 LinkedList 既可以當做Queue,又可以當做 Stack。在將 LinkedList 當做 Stack 時,使用 pop()、push()、peek() 需要注意的是 LinkedList 內部是將連結串列頭部當做棧頂,連結串列尾部當做棧底。
7️⃣隨機存取慢、插入刪除速度快。
import java.util.Iterator; import java.util.Deque; import java.util.LinkedList; import java.util.Queue; public class LinkedlistDemo { public static void main(String[] args) { linkedShow(); System.out.println(">----------一&&&二----------<"); linkedDeque(); System.out.println(">----------二&&&三----------<"); linkedListPop(); } public static void linkedShow() { // 建立一個佇列 Queue<Integer> queue = new LinkedList<>(); //新增元素 queue.add(1); queue.offer(22); for (Integer integer : queue) { System.out.println("queue的add()和offer()驗證:" + integer); } // 獲取但不移除此佇列的頭 Integer a = queue.peek(); // 輸出獲取的元素並列印出元素的長度,驗證一下長度看看是否有變化 System.out.println("queue.peek():" + a + ",後長度為:" + queue.size()); // 獲取並移除此佇列的頭 Integer bInteger = queue.poll(); // 輸出獲取的元素並列印出元素的長度,驗證一下長度看看是否有變化 System.out.println("queue.poll():" + bInteger + ",後長度為:" + queue.size()); } public static void linkedDeque() { Deque<Integer> deque = new LinkedList<>(); // 新增元素 deque.add(3); // 在第一個位置新增元素 deque.offerFirst(5); // 在最後一個位置新增元素 deque.offerLast(7); for (Integer integer : deque) { System.out.println("deque新增驗證:" + integer); } // 取出不移除元素 Integer kInteger = deque.peekFirst(); Integer mInteger = deque.peekLast(); System.out.println("deque.peek():" + kInteger + ">>>>" + mInteger + ",後長度為:" + deque.size()); // 取出並移除元素方法 Integer kInteger2 = deque.pollFirst(); Integer mInteger2 = deque.pollLast(); System.out.println("deque.poll():" + kInteger2 + ">>>>" + mInteger2 + ",後長度為:" + deque.size()); } public static void linkedListPop() { // 建立一個linkedlist集合 LinkedList<Integer> linkedList = new LinkedList<>(); // 新增元素 linkedList.push(9); linkedList.push(7); linkedList.push(5); linkedList.push(3); linkedList.push(1); for (Integer integer : linkedList) { System.out.println("linkedList.push():" + integer); } // 使用迭代器進行正向輸出 Iterator<Integer> inIterator = linkedList.iterator(); while (inIterator.hasNext()) { Integer integer = inIterator.next(); System.out.println(integer); } System.out.println("-------分割線-------"); // 使用迭代器反向輸出結果 Iterator<Integer> inIterator1 = linkedList.descendingIterator(); while (inIterator1.hasNext()) { Integer integer = inIterator1.next(); System.out.println(integer); } System.out.println("-------分割線-------"); // 使用for迴圈進行輸出元素並移除 for (int i = 0; i <= 4; i++) { Integer result = linkedList.pop(); System.out.println("linkedList.pop():" + result + ">------<" + ",後長度為:" + linkedList.size()); } } }
輸出如下:
queue的add()和offer()驗證:1
queue的add()和offer()驗證:22
queue.peek():1,後長度為:2
queue.poll():1,後長度為:1
>----------一&&&二----------<
deque新增驗證:5
deque新增驗證:3
deque新增驗證:7
deque.peek():5>>>>7,後長度為:3
deque.poll():5>>>>7,後長度為:1
>----------二&&&三----------<
linkedList.push():1
linkedList.push():3
linkedList.push():5
linkedList.push():7
linkedList.push():9
1
3
5
7
9
-------分割線-------
9
7
5
3
1
-------分割線-------
linkedList.pop():1>------<,後長度為:4
linkedList.pop():3>------<,後長度為:3
linkedList.pop():5>------<,後長度為:2
linkedList.pop():7>------<,後長度為:1
linkedList.pop():9>------<,後長度為:0Process finished with exit code 0
到此這篇關於Java實現雙端連結串列LinkedList的文章就介紹到這了,更多相關Java 雙端連結串列LinkedList內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45