欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時(shí)間:2020年03月17日 10:31:47   作者:WFaceBoss  
這篇文章主要介紹了Java鏈表中元素刪除的實(shí)現(xiàn)方法,結(jié)合實(shí)例形式分析了java只刪除鏈表中一個(gè)元素的相關(guān)操作原理、實(shí)現(xiàn)方法與注意事項(xiàng),需要的朋友可以參考下

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

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

一、圖示刪除邏輯

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

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

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

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

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

3.刪除操作

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

代碼為:

prev.next=delNode.next;

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

代碼為:

delNode.next=null;

二、代碼實(shí)現(xiàn)刪除邏輯

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

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

//從鏈表刪除第index(0-based)個(gè)位置的元素 ,返回刪除的元素 (實(shí)際不常用,練習(xí)用)
  public E remove(int index) {
    if (index < 0 || index >= size) {
      throw new IllegalArgumentException("remove failed,Illegal index");
    }

    //獲取虛擬頭節(jié)點(diǎn)
    Node<E> prev = dummyHead;
    for (int i = 0; i < index; i++) {
      //獲取到刪除元素之前節(jié)點(diǎn)
      prev = prev.next;
    }

    Node<E> retNode = prev.next;//被刪除的元素
    prev.next = retNode.next;
    retNode.next = null;
    size--;

    return retNode.e;
  }

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

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

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

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

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

//從鏈表中刪除最后一個(gè)元素,返回刪除的元素
  public E removeLast() {
    return remove(size - 1);
  }

三、測試刪除邏輯

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

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é)點(diǎn)============");
    linkedList.remove(2);
    System.out.println(linkedList);
  }
}

結(jié)果為:

 四、鏈表的時(shí)間復(fù)雜度分析

4.1 添加操作的時(shí)間復(fù)雜度

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

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

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

4.2 刪除操作的時(shí)間復(fù)雜度

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

(2)刪除鏈表的第一個(gè)元素(removeFirst()),時(shí)間復(fù)雜度為O(1)

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

 

 4.3 修改操作

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

4.4 查找操作

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

 

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

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

關(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é)點(diǎn)技巧總結(jié)》、《Java文件與目錄操作技巧匯總》和《Java緩存操作技巧匯總

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

相關(guān)文章

  • Seata AT模式如何實(shí)現(xiàn)行鎖詳解

    Seata AT模式如何實(shí)現(xiàn)行鎖詳解

    這篇文章主要為大家介紹了Seata AT模式如何實(shí)現(xiàn)行鎖詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-11-11
  • Mapper類中存在名稱相同的方法重載報(bào)錯(cuò)問題

    Mapper類中存在名稱相同的方法重載報(bào)錯(cuò)問題

    這篇文章主要介紹了Mapper類中存在名稱相同的方法重載報(bào)錯(cuò)問題,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-03-03
  • Spring工廠方法創(chuàng)建(實(shí)例化)bean實(shí)例代碼

    Spring工廠方法創(chuàng)建(實(shí)例化)bean實(shí)例代碼

    這篇文章主要介紹了Spring工廠方法創(chuàng)建bean實(shí)例代碼,具有一定借鑒價(jià)值,需要的朋友可以參考下
    2018-01-01
  • SpringBoot將Bean放入容器的五種方式

    SpringBoot將Bean放入容器的五種方式

    這篇文章給大家介紹了SpringBoot將Bean放入容器的五種方式,文中通過代碼示例給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下
    2024-02-02
  • java中Hashmap的get方法使用

    java中Hashmap的get方法使用

    這篇文章主要介紹了java中Hashmap的get方法使用,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-09-09
  • java??常見位邏輯運(yùn)算符梳理

    java??常見位邏輯運(yùn)算符梳理

    這篇文章主要介紹了java常見位邏輯運(yùn)算符梳理,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,感興趣的小伙伴可以參一下下面文章詳細(xì)內(nèi)容
    2022-08-08
  • Java中的自旋鎖解析

    Java中的自旋鎖解析

    這篇文章主要介紹了Java中的自旋鎖解析,自旋鎖是指當(dāng)一個(gè)線程嘗試獲取某個(gè)鎖時(shí),如果該鎖已被其他線程占用,就一直循環(huán)檢測鎖是否被釋放,而不是進(jìn)入線程掛起或睡眠狀態(tài),需要的朋友可以參考下
    2023-10-10
  • JAVA面試題 從源碼角度分析StringBuffer和StringBuilder的區(qū)別

    JAVA面試題 從源碼角度分析StringBuffer和StringBuilder的區(qū)別

    這篇文章主要介紹了JAVA面試題 從源碼角度分析StringBuffer和StringBuilder的區(qū)別,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,下面我們來一起學(xué)習(xí)下吧
    2019-07-07
  • Java servlet通過事件驅(qū)動進(jìn)行高性能長輪詢詳解

    Java servlet通過事件驅(qū)動進(jìn)行高性能長輪詢詳解

    這篇文章主要介紹了基于servlet3.0+事件驅(qū)動實(shí)現(xiàn)高性能長輪詢的操作,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2022-06-06
  • idea中開啟Run Dashboard 和 快速復(fù)制項(xiàng)目并改變端口的方法

    idea中開啟Run Dashboard 和 快速復(fù)制項(xiàng)目并改變端口的方法

    這篇文章主要介紹了idea中開啟Run Dashboard 和 快速復(fù)制項(xiàng)目并改變端口的方法,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-08-08

最新評論