3.1鏈表----鏈表(Linked List)入門

在分析鏈表以前,咱們先來對以前的動態數組、棧、隊列總結一下:數組

(1)底層依託於靜態數組數據結構

(2)依靠resize解決固定容量問題ide

 

(3)是一種假的的動態數據結構函數

1.什麼是鏈表學習

能夠從如下兩個部分來理解什麼是鏈表this

(1)最簡單的動態數據結構,是一種真正的動態數據結構;spa

(2)是一種數據的存儲方式,數據存儲在"節點"(Node)中設計

1.1結構基本代碼:code

class Node{
  E e;
  Node next;
}

1.2 圖示以下:blog

1.3 優勢、缺點

優勢:真正的動態,不須要處理固定容量的問題

缺點:喪失了隨機訪問的能力,也就是不能經過索引進行訪問,只能next來進行查找

1.4數組與鏈表的對比

 1.5 基本的鏈表節點結構代碼:

新建一個package(LinkedList),而後新建一個類LinkedList,在該類中封裝一個私有的節點,便於後續對於節點的使用。

package LinkedList;

public class LinkedList<E> {
    //將Node節點設計成私有的類中類
    private class Node<E> {
        public E e;
        public Node next;

        //兩個參數的構造函數
        public Node(E e, Node next) {
            this.e = e;
            this.next = next;
        }

        //一個參數的構造函數
        public Node(E e) {
            this.e = e;
            this.next = null;
        }

        //無參構造函數
        public Node() {
            this(null, null);
        }

        @Override
        public String toString() {
            return e.toString();
        }
    }
}

在本小節中先是簡單瞭解了一下理論知識,而後把基本的鏈表節點結構使用代碼來實現,下一小節咱們繼續來學習如何如何在鏈表中添加元素。

相關文章
相關標籤/搜索