溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶(hù)服務(wù)條款》

關(guān)于鏈表的知識(shí)點(diǎn)有哪些

發(fā)布時(shí)間:2021-10-29 09:51:47 來(lái)源:億速云 閱讀:152 作者:iii 欄目:web開(kāi)發(fā)

本篇內(nèi)容介紹了“關(guān)于鏈表的知識(shí)點(diǎn)有哪些”的有關(guān)知識(shí),在實(shí)際案例的操作過(guò)程中,不少人都會(huì)遇到這樣的困境,接下來(lái)就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!

一 單向鏈表

1.1  單向鏈表原理圖

單向鏈表的一個(gè)鏈結(jié)點(diǎn)包含數(shù)據(jù)域和下一個(gè)鏈結(jié)點(diǎn)的指針。頭結(jié)點(diǎn)也包含數(shù)據(jù)域和指針域,但是一般為了方便查找,頭節(jié)點(diǎn)不寫(xiě)數(shù)據(jù),最后一個(gè)結(jié)點(diǎn)的指針指向空。

關(guān)于鏈表的知識(shí)點(diǎn)有哪些

1.2 實(shí)現(xiàn)單向鏈表的存儲(chǔ)等操作

創(chuàng)建一個(gè)鏈結(jié)點(diǎn)的實(shí)體類(lèi)

public class Node {      // 數(shù)據(jù)域     public long data;     // 指針域     public Node next;      public Node(long value){         this.data = value;     } }

1.2.1 插入一個(gè)節(jié)點(diǎn)

在頭節(jié)點(diǎn)后插入一個(gè)結(jié)點(diǎn),第一步需要將新插入的結(jié)點(diǎn)指向頭結(jié)點(diǎn)指向的結(jié)點(diǎn),第二步將頭結(jié)點(diǎn)指向新插入的結(jié)點(diǎn)。插入結(jié)點(diǎn)只需要改變一個(gè)引用,所以復(fù)雜度為O(1)。

關(guān)于鏈表的知識(shí)點(diǎn)有哪些

public class LinkList {      private Node head;     /**      * 在頭節(jié)點(diǎn)之后插入一個(gè)節(jié)點(diǎn)      */     public void insertFirst(long value){         Node node = new Node(value);         node.next = head;         head = node;     } }

1.2.2 頭結(jié)點(diǎn)后刪除一個(gè)結(jié)點(diǎn)

在頭結(jié)點(diǎn)后刪除一個(gè)結(jié)點(diǎn),就是讓頭結(jié)點(diǎn)指向這個(gè)結(jié)點(diǎn)的下一個(gè)結(jié)點(diǎn)。復(fù)雜度也是O(1)。

關(guān)于鏈表的知識(shí)點(diǎn)有哪些

public Node deleteFirst(){     Node tmp = head;     head = tmp.next;     return tmp; }

1.2.3 根據(jù)數(shù)據(jù)域查找結(jié)點(diǎn)

查找需要比對(duì)每個(gè)結(jié)點(diǎn)的數(shù)據(jù),理論上查找一個(gè)結(jié)點(diǎn)平均需要N/2次,所以復(fù)雜度為O(N)。

public Node find(long value){      Node current = head;     while (current.data != value){         if(current.next == null){             return null;         }         current = current.next;     }     return current; }

1.2.4 根據(jù)數(shù)據(jù)與刪除結(jié)點(diǎn)

查找需要比對(duì)每個(gè)結(jié)點(diǎn)的數(shù)據(jù),理論上刪除一個(gè)結(jié)點(diǎn)平均需要N/2次,所以復(fù)雜度為O(N)。

public Node delete(int value){     Node current = head;     // 當(dāng)前結(jié)點(diǎn)的前一個(gè)結(jié)點(diǎn)     Node pre = head;     while (current.data != value){         if(current.next == null){             return null;         }         pre = current;         current = current.next;     }     if(current == head){         head = head.next;     }else{         pre.next = current.next;     }     return current; }

二 雙端鏈表

2.1 雙端鏈表原理圖

雙端鏈表是在單向鏈表的基礎(chǔ)上,頭結(jié)點(diǎn)增加了一個(gè)尾結(jié)點(diǎn)的引用。

關(guān)于鏈表的知識(shí)點(diǎn)有哪些

2.2 實(shí)現(xiàn)雙端鏈表的存儲(chǔ)等操作

2.2.1 從頭部插入結(jié)點(diǎn)

如果鏈表為空,則設(shè)置尾結(jié)點(diǎn)就是新添加的結(jié)點(diǎn)。復(fù)雜度為O(1)。

public class FirstLastLinkList {      private Node first;     private Node last;     /**      * 在頭結(jié)點(diǎn)之后插入一個(gè)節(jié)點(diǎn)      */     public void insertFirst(long value){         Node node = new Node(value);         if(first == null){             last = node;         }         node.next = first;         first = node;     } }

2.2.2 從尾部插入結(jié)點(diǎn)

如果鏈表為空,則設(shè)置頭結(jié)點(diǎn)為新添加的結(jié)點(diǎn),否則設(shè)置尾結(jié)點(diǎn)的后一個(gè)結(jié)點(diǎn)為新添加的結(jié)點(diǎn)。復(fù)雜度為O(1)。

public void insertLast(long value){     Node node = new Node(value);     if(first == null){         first = node;     }else{         last.next = node;     }     last = node; }

2.2.3 從頭部進(jìn)行刪除

判斷頭結(jié)點(diǎn)是否有下一個(gè)結(jié)點(diǎn),如果沒(méi)有則設(shè)置尾結(jié)點(diǎn)為null,復(fù)雜度為O(1)。

public Node deleteFirst(){      Node tmp = first;     if(first.next == null){         last = null;     }     first = tmp.next;     return tmp; }

三 雙向鏈表

3.1 雙向鏈表原理圖

每個(gè)結(jié)點(diǎn)除了保存對(duì)后一個(gè)結(jié)點(diǎn)的引用外,還保存著對(duì)前一個(gè)結(jié)點(diǎn)的引用。

關(guān)于鏈表的知識(shí)點(diǎn)有哪些

3.2 實(shí)現(xiàn)雙向鏈表的存儲(chǔ)等操作鏈結(jié)點(diǎn)實(shí)體類(lèi)

public class Node {      // 數(shù)據(jù)域     public long data;     // 后一個(gè)結(jié)點(diǎn)指針域     public Node next;     // 前一個(gè)結(jié)點(diǎn)指針域     public Node prev;      public Node(long value){         this.data = value;     } }

3.2.1 從頭部插入結(jié)點(diǎn)

如果鏈表為空,則設(shè)置尾結(jié)點(diǎn)為新添加的結(jié)點(diǎn),如果不為空,還需要設(shè)置頭結(jié)點(diǎn)的前一個(gè)結(jié)點(diǎn)為新添加的結(jié)點(diǎn)。插入結(jié)點(diǎn)只需要改變兩個(gè)結(jié)點(diǎn)的引用,所以復(fù)雜度為O(1)。

關(guān)于鏈表的知識(shí)點(diǎn)有哪些

public class DoubleLinkList {      private Node first;     private Node last;      /**      * 在頭結(jié)點(diǎn)之后插入一個(gè)節(jié)點(diǎn)      */     public void insertFirst(long value){         Node node = new Node(value);         if(first == null){             last = node;         } else{             first.prev = node;         }         node.next = first;         first = node;     } }

3.2.2 從尾部插入結(jié)點(diǎn)

如果鏈表為空,則設(shè)置頭結(jié)點(diǎn)為新添加的結(jié)點(diǎn),否則設(shè)置尾結(jié)點(diǎn)的后一個(gè)結(jié)點(diǎn)為新添加的結(jié)點(diǎn)。同時(shí)設(shè)置新添加的結(jié)點(diǎn)的前一個(gè)結(jié)點(diǎn)為尾結(jié)點(diǎn)。插入結(jié)點(diǎn)只需要改變1個(gè)結(jié)點(diǎn)的引用,所以復(fù)雜度為O(1)。

public void insertLast(long value){     Node node = new Node(value);     if(first == null){         first = node;     }else{         last.next = node;         node.prev = last;     }     last = node; }

3.2.3 從頭部刪除結(jié)點(diǎn)

判斷頭結(jié)點(diǎn)是否有下一個(gè)結(jié)點(diǎn),如果沒(méi)有則設(shè)置尾結(jié)點(diǎn)為null,否則設(shè)置頭結(jié)點(diǎn)的下一個(gè)結(jié)點(diǎn)的prev為null。復(fù)雜度也為O(1)。

關(guān)于鏈表的知識(shí)點(diǎn)有哪些

public Node deleteFirst(){      Node tmp = first;     if(first.next == null){         last = null;     }else{         first.next.prev = null;     }     first = tmp.next;     return tmp; }

3.2.4 從尾部刪除結(jié)點(diǎn)

如果頭結(jié)點(diǎn)后沒(méi)有其他結(jié)點(diǎn),則設(shè)置頭結(jié)點(diǎn)為null,否則設(shè)置尾結(jié)點(diǎn)的前一個(gè)結(jié)點(diǎn)的next為null,設(shè)置尾結(jié)點(diǎn)為前一個(gè)結(jié)點(diǎn)。復(fù)雜度為O(1)。

public Node deleteLast(){      Node tmp = last;      if(first.next == null){         first = null;     }else{         last.prev.next = null;       }     last = last.prev;     return last; }

“關(guān)于鏈表的知識(shí)點(diǎn)有哪些”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識(shí)可以關(guān)注億速云網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(shí)用文章!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI