日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術(shù)文章
文章詳情頁

Java鏈表中元素刪除的實現(xiàn)方法詳解【只刪除一個元素情況】

瀏覽:181日期:2022-09-04 13:14:36

本文實例講述了Java鏈表中元素刪除的實現(xiàn)方法。分享給大家供大家參考,具體如下:

該部分與上一節(jié)是息息相關(guān)的,關(guān)于如何在鏈表中刪除元素,我們一步一步來分析:

一、圖示刪除邏輯

假設(shè)我們需要在鏈表中刪除索引為2位置的元素,此時鏈表結(jié)構(gòu)為:

Java鏈表中元素刪除的實現(xiàn)方法詳解【只刪除一個元素情況】

若要刪除索引為2位置的元素,需要獲取索引為2位置的元素之前的前置節(jié)點(此時為索引為1的位置的元素),因此我們需要設(shè)計一個變量prev來記錄前置節(jié)點。

1.初始時變量prev指向虛擬頭結(jié)點dummyHead:

Java鏈表中元素刪除的實現(xiàn)方法詳解【只刪除一個元素情況】

2.尋找到前置節(jié)點位置,(對于該例子前置節(jié)點為索引為1的位置的元素)。

Java鏈表中元素刪除的實現(xiàn)方法詳解【只刪除一個元素情況】

則此時prev記錄的next即為需要刪除的節(jié)點,記為delNode變量。

Java鏈表中元素刪除的實現(xiàn)方法詳解【只刪除一個元素情況】

3.刪除操作

第一步:將prev的next指向delNode的next,如圖:

Java鏈表中元素刪除的實現(xiàn)方法詳解【只刪除一個元素情況】

代碼為:

prev.next=delNode.next;

第二步:為了java能夠回收這個被刪除的空間,我們手動讓需要被刪除的節(jié)點從鏈表中脫離開來,也就是delNode的next變?yōu)閚ull。

Java鏈表中元素刪除的實現(xiàn)方法詳解【只刪除一個元素情況】

代碼為:

delNode.next=null;二、代碼實現(xiàn)刪除邏輯

2.1 從鏈表刪除第index(0-based)個位置的元素 ,返回刪除的元素

首先,初始化當前前置節(jié)點指向虛擬頭結(jié)點,然后遍歷尋找到需要被刪除節(jié)點的前置節(jié)點,最后執(zhí)行刪除邏輯。

//從鏈表刪除第index(0-based)個位置的元素 ,返回刪除的元素 (實際不常用,練習用) public E remove(int index) { if (index < 0 || index >= size) { throw new IllegalArgumentException('remove failed,Illegal index'); } //獲取虛擬頭節(jié)點 Node<E> prev = dummyHead; for (int i = 0; i < index; i++) { //獲取到刪除元素之前節(jié)點 prev = prev.next; } Node<E> retNode = prev.next;//被刪除的元素 prev.next = retNode.next; retNode.next = null; size--; return retNode.e; }

2.2 從鏈表中刪除第一個元素,返回刪除的元素

基于remove(int index)方法實現(xiàn)該方法:

//從鏈表中刪除第一個元素,返回刪除的元素 public E removeFirst() { return remove(0); }

2.3 從鏈表中刪除最后一個元素,返回刪除的元素

基于remove(int index)方法實現(xiàn)該方法:

//從鏈表中刪除最后一個元素,返回刪除的元素 public E removeLast() { return remove(size - 1); }三、測試刪除邏輯

基于上一節(jié)的測試代碼,我們新增刪除邏輯代碼,此時貼出全部測試代碼:

package LinkedList;public class TestMain { public static void main(String[] args) { LinkedList<Integer> linkedList = new LinkedList<Integer>(); System.out.println('============在鏈表頭部添加============'); for (int i = 0; i < 5; i++) { linkedList.addFirst(i); System.out.println(linkedList); } System.out.println('============修改鏈表============'); linkedList.set(2, 666); System.out.println(linkedList); System.out.println('============刪除鏈表中666節(jié)點============'); linkedList.remove(2); System.out.println(linkedList); }}

結(jié)果為:

Java鏈表中元素刪除的實現(xiàn)方法詳解【只刪除一個元素情況】

四、鏈表的時間復雜度分析

4.1 添加操作的時間復雜度

(1)在鏈表尾部添加(addLast())需要從頭遍歷,時間復雜度為O(n);

(2)在鏈表頭部添加(addFirst()),時間復雜度為O(1);

(3)在鏈表任意位置添加(add(int index,E e)),平均情況下為O(n/2)=O(n);

Java鏈表中元素刪除的實現(xiàn)方法詳解【只刪除一個元素情況】

4.2 刪除操作的時間復雜度

(1)刪除鏈表最后一個元素(removeLast()),需要遍歷找到最后元素的前一個元素,故時間復雜度為O(n);

(2)刪除鏈表的第一個元素(removeFirst()),時間復雜度為O(1)

(3)刪除鏈表中任意位置節(jié)點(remove(index)),平均情況下時間復雜度為O(n/2)=O(n);

Java鏈表中元素刪除的實現(xiàn)方法詳解【只刪除一個元素情況】

4.3 修改操作

由于鏈表不支持隨機訪問,需要從頭開始尋找直到找到需要修改的節(jié)點,故時間復雜度為O(n)

Java鏈表中元素刪除的實現(xiàn)方法詳解【只刪除一個元素情況】

4.4 查找操作

由于鏈表不支持隨機訪問,需要從頭開始尋找直到找到需要的節(jié)點,故時間復雜度為O(n)

Java鏈表中元素刪除的實現(xiàn)方法詳解【只刪除一個元素情況】

從上不難看出,關(guān)于鏈表的添加操作、刪除操作、修改操作、查找操作的時間復雜度均為O(n),看到這個頓時心涼了半截,這個還搞個mao,還不如數(shù)組呢,其實確實是這樣的,因為對于數(shù)組來說,只要有索引即可實現(xiàn)快速訪問。但是對于鏈表來說,我們?nèi)绻粚︽湵眍^進行添加操作、刪除操作、查找操作那么它的的時間復雜度為均O(1),這時和數(shù)組是一樣,是動態(tài)的,不會大量的浪費內(nèi)存空間,這就是它的優(yōu)勢,由于鏈表是最基礎(chǔ)的動態(tài)數(shù)據(jù)結(jié)構(gòu),在此基礎(chǔ)上將會有更多關(guān)于鏈表的應用。

Java鏈表中元素刪除的實現(xiàn)方法詳解【只刪除一個元素情況】

關(guān)于本小節(jié),若您覺得還行、還過得去,麻煩給個推薦吧,謝謝!!

關(guān)于鏈表的源碼 https://github.com/FelixBin/dataStructure/tree/master/src/LinkedList

更多關(guān)于java算法相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Java數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Java操作DOM節(jié)點技巧總結(jié)》、《Java文件與目錄操作技巧匯總》和《Java緩存操作技巧匯總》

希望本文所述對大家java程序設(shè)計有所幫助。

標簽: Java
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
激情五月综合网| 国产精品va| 91精品国产成人观看| 日韩一区自拍| 91精品一区二区三区综合在线爱| 国产精品成人一区二区不卡| 国产一区2区| 欧美亚洲三区| 欧美视频久久| 国产精品欧美三级在线观看| 日韩在线网址| 石原莉奈一区二区三区在线观看| 日韩专区一卡二卡| 亚洲精品乱码| 欧美一区=区三区| 国产精品一区高清| 成人在线超碰| 久久精品欧美一区| 欧美中文字幕| 亚洲欧美久久精品| 国产精品资源| 天堂中文在线播放| 久久久国产精品一区二区中文| 欧美~级网站不卡| 中文精品电影| 国产精品久久久久久模特| 丁香婷婷久久| 亚洲激情中文在线| 少妇精品在线| 精品免费av| 婷婷久久一区| 日韩欧美在线精品| 麻豆成人综合网| 日本高清不卡一区二区三区视频 | 亚洲乱码久久| 欧美亚洲免费| 精品国产乱码久久久久久樱花| 日韩国产欧美| 一区二区亚洲视频| 精品国产一区二区三区性色av| 欧美日韩精品在线一区| 亚洲综合中文| 国产一区二区色噜噜| 亚洲色诱最新| 欧美xxxx性| 免费av一区| 国产毛片精品久久| 免费在线小视频| 在线看片一区| 福利一区二区三区视频在线观看| 99成人在线| 亚洲乱码一区| 国产精品原创| 五月激激激综合网色播| 91嫩草亚洲精品| 国产韩日影视精品| 国产精品一区毛片| 午夜久久久久| 麻豆国产精品一区二区三区| 免费av一区| 国产精品99久久免费观看| 免费不卡中文字幕在线| 国产精品一区二区三区av麻| 午夜av一区| 精品中文在线| 亚洲精品女人| 欧美xxxx中国| 日韩精品一区二区三区中文在线| 青青青免费在线视频| 日韩av二区在线播放| 国产99精品| 美女精品一区二区| 热久久久久久久| 日韩欧美三级| 国产精品成人**免费视频| 视频一区二区三区在线| 欧美gv在线| 免费在线欧美黄色| 亚洲丝袜美腿一区| 婷婷激情久久| 欧美国产小视频| 日韩 欧美一区二区三区| 久久久9色精品国产一区二区三区| 国产日本精品| 免费日本视频一区| 久久高清免费| 国产a亚洲精品| 日本成人手机在线| 国产亚洲网站| 国产91精品对白在线播放| 成人在线免费观看网站| 日本天堂一区| 亚久久调教视频| 亚洲欧美成人综合| 国产高清一区| 成人午夜国产| 免费观看亚洲天堂| 欧美视频二区| 亚洲精品极品| 蜜芽一区二区三区| 99热免费精品| 欧美日韩国产在线观看网站 | a天堂资源在线| 国产精品v一区二区三区| 日韩中文字幕无砖| 亚洲性视频在线| 免费在线观看日韩欧美| 午夜精品网站| 欧美高清不卡| 高清一区二区| 麻豆精品视频在线观看| 国产日韩一区| 69堂精品视频在线播放| 中文字幕日韩高清在线| 先锋亚洲精品| 噜噜噜久久亚洲精品国产品小说| 午夜久久久久| 国产视频欧美| 蜜臀久久久久久久| 亚洲精选av| 天堂俺去俺来也www久久婷婷| 免费一区二区视频| 中文字幕亚洲在线观看| 综合亚洲自拍| 亚洲精品福利| 日本91福利区| 日本午夜精品久久久| 欧美一区免费| 国产精品亚洲欧美一级在线| 国产欧美日韩| 久久影视三级福利片| 久久久久观看| 中文字幕高清在线播放| 影视先锋久久| 激情综合自拍| 制服诱惑一区二区| 国产女优一区| 综合精品一区| 青青伊人久久| 青草综合视频| 国产精区一区二区| 欧美亚洲三区| 捆绑调教美女网站视频一区| 高清一区二区三区av| 国产亚洲一区二区手机在线观看| yellow在线观看网址| 99久久99久久精品国产片果冰| 在线国产一区| 亚洲精品日韩久久| 国产区精品区| 成人在线视频免费看| 91精品一区国产高清在线gif| jiujiure精品视频播放| 国产精品日韩久久久| 久久99伊人| 97se亚洲| 狠狠躁少妇一区二区三区| 欧美va天堂在线| 久久亚洲电影| 欧美日韩亚洲一区三区| 国产一区二区三区四区大秀| 激情综合网站| 天堂va欧美ⅴa亚洲va一国产| 国产精品综合| av资源中文在线| 影音先锋久久| 国产亚洲久久| 激情亚洲影院在线观看| 视频一区国产视频| 日韩超碰人人爽人人做人人添| 久久精品免视看国产成人| 日韩三区在线| 日本一区福利在线| 精品亚洲成人| 亚洲精品123区| 国产精品sm| 欧美中文字幕一区二区| 久久国产三级| 99久久夜色精品国产亚洲1000部| 亚洲欧美在线综合| 国产不卡人人| 亚洲欧洲免费| 波多视频一区| 日本在线一区二区三区| 国产不卡人人| 亚洲精一区二区三区| 精品久久电影| 日韩一区精品视频| av最新在线| 日本三级亚洲精品| 国产尤物精品| 欧美黑人巨大videos精品| 亚洲欧美日韩视频二区| 成人在线丰满少妇av| 四虎国产精品免费久久| 97精品国产福利一区二区三区| 亚洲精选av| 欧美日一区二区| 国产黄色精品| 亚洲精品99|