真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

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

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

成都網(wǎng)站設計、成都做網(wǎng)站的關(guān)注點不是能為您做些什么網(wǎng)站,而是怎么做網(wǎng)站,有沒有做好網(wǎng)站,給創(chuàng)新互聯(lián)建站一個展示的機會來證明自己,這并不會花費您太多時間,或許會給您帶來新的靈感和驚喜。面向用戶友好,注重用戶體驗,一切以用戶為中心。

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

一、圖示刪除邏輯

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

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

若要刪除索引為2位置的元素,需要獲取索引為2位置的元素之前的前置節(jié)點(此時為索引為1的位置的元素),因此我們需要設計一個變量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 prev = dummyHead;
    for (int i = 0; i < index; i++) {
      //獲取到刪除元素之前節(jié)點
      prev = prev.next;
    }

    Node 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 linkedList = new LinkedList();

    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程序設計有所幫助。


分享標題:Java鏈表中元素刪除的實現(xiàn)方法詳解【只刪除一個元素情況】
URL網(wǎng)址:http://weahome.cn/article/gcjjsp.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部