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

Java語言之LinkedList和鏈表的實現(xiàn)方法

 更新時間:2023年05月17日 15:44:18   作者:tq02  
LinkedList是由傳統(tǒng)的鏈表數(shù)據(jù)結(jié)構(gòu)演變而來的,鏈表是一種基本的數(shù)據(jù)結(jié)構(gòu),它可以動態(tài)地增加或刪除元素,下面這篇文章主要給大家介紹了關(guān)于Java語言之LinkedList和鏈表的實現(xiàn)方法,需要的朋友可以參考下

一.鏈表概念

鏈表是一種物理存儲結(jié)構(gòu)上非連續(xù)存儲結(jié)構(gòu),數(shù)據(jù)元素的邏輯順序是通過鏈表中的引用鏈接次序?qū)崿F(xiàn)的 。

邏輯結(jié)構(gòu):

注:1、如上圖,相當(dāng)于火車車廂,每一節(jié)都相連在一起。

       2、各個結(jié)點連接的方式:通過地址連接,在內(nèi)存當(dāng)中,相鄰結(jié)點在內(nèi)存中不一定相鄰。

       3、所有結(jié)點都在  堆 中申請出來。

       4、 每個結(jié)點包括兩個部分:一個是存儲數(shù)據(jù)元素的數(shù)據(jù)域,另一個是存儲下一個結(jié)點地址的指針域。

二.鏈表的分類 

 1.單向、雙向鏈表

 注:無論單向還是雙向,都是一個結(jié)點存儲著下(上)一個結(jié)點。

2.帶頭、不帶頭結(jié)點 鏈表

 注:無頭和帶頭結(jié)點的主要區(qū)別:有一個起始結(jié)點。

3.循環(huán)、非循環(huán)鏈表 

循環(huán)鏈表,就是指:頭、尾結(jié)點有聯(lián)系。

在鏈表結(jié)構(gòu)中,這是主要的鏈表,但是這些鏈表種類還可以結(jié)合,如:帶頭雙向循環(huán)鏈表、雙向循環(huán)鏈表等等。

鏈表的種類很多,但都大同小異,我們主要學(xué)習(xí)兩種鏈表:

1、無頭單向非循環(huán)鏈表:結(jié)構(gòu)簡單,一般不會單獨用來存數(shù)據(jù)。實際中更多是作為其他數(shù)據(jù)結(jié)構(gòu)的子結(jié)構(gòu),如哈希桶、圖的鄰接表等等。另外這種結(jié)構(gòu)在筆試面試中出現(xiàn)很多。              

2、無頭雙向鏈表:在Java的集合框架庫中LinkedList底層實現(xiàn)就是無頭雙向循環(huán)鏈表

三.無頭單向非循環(huán)鏈表的實現(xiàn)

3.1創(chuàng)建簡單鏈表

重點:每個結(jié)點存儲著下一個結(jié)點的地址。

創(chuàng)建鏈表代碼實現(xiàn):

public class SingleLinkedList {
      static class List{
        int item;   //	存儲數(shù)據(jù)
        List next;   //	指向下一個結(jié)點
        public List(int item) {
            this.item = item;
        }
        public List() {};
    }
//各種鏈表實現(xiàn)方法
//頭插法
public void addFirst(int data){
} 
    //尾插法
public void addLast(int data){
} 
    //任意位置插入,第一個數(shù)據(jù)節(jié)點為0號下標(biāo)
public void addIndex(int index,int data){
} 
    //查找是否包含關(guān)鍵字key是否在單鏈表當(dāng)中
public boolean contains(int key){
return false;
} 
    //刪除第一次出現(xiàn)關(guān)鍵字為key的節(jié)點
public void remove(int key){
}
    //得到單鏈表的長度
public int size(){
    return -1;
}
    //鏈表的清空
public void clear() {
}
    //展示鏈表
public void display() {}

3.2 鏈表基本方法實現(xiàn)

1.遍歷鏈表元素

public void show() {
        //這里不是定義了一個節(jié)點 這里只是一個引用
        ListNode cur = head;
        while (cur != null) {
            System.out.print(cur.val+" ");
            cur = cur.next;
        }
        System.out.println();
    }

2.獲取鏈表長度

 public int size(){
        int count = 0;
        ListNode cur = head;
        while (cur != null) {
            count++;
            cur = cur.next;
        }
        return count;
    }

 3.查詢數(shù)據(jù)

public boolean contains(int key){
        ListNode cur = head;
        while (cur != null) {
            //如果val值 是引用類型  那么這里得用equals來進(jìn)行比較?。?!
            if(cur.val == key) {
                return true;
            }
            cur = cur.next;
        }
        return false;
    }

4.鏈表的清空

public void clear() {
        //將所有結(jié)點都置空,更為安全
        while (head != null) {
            ListNode headNext = head.next;
            head.next = null;
            head = headNext;
        }
    }

3.3四大基本功能      

3.3.1 、增加元素結(jié)點

1.頭插法:將新增結(jié)點放在鏈表的頭部。

public void addFirst(int data){
        ListNode node = new ListNode(data);
        node.next = head;
        head = node;
    }

2.尾插法:將新增結(jié)點直接連接在鏈表的尾部

 public void addLast(int data){
        ListNode node = new ListNode(data);
        if(head == null) {
            head = node;
            return;
        }
        ListNode cur = head;
        while (cur.next != null) {
            cur = cur.next;
        }
        //cur 指向的節(jié)點就是尾巴節(jié)點
        cur.next = node;
    }

3.選擇下標(biāo)值,添加結(jié)點

 public void addIndex(int index,int data){
        int len = size();
        //0、判斷index位置的合法性
        if(index < 0 || index > len) {
            throw new IndexOutOfBounds("任意位置插入數(shù)據(jù)的時候,index位置不合法: "+index);
        }
        if(index == 0) {
            addFirst(data);
            return;
        }
        if(index == len) {
            addLast(data);
            return;
        }
        //1、先找到index-1位置的節(jié)點
        ListNode cur = findIndex(index);
        //2、進(jìn)行插入
        ListNode node = new ListNode(data);
        node.next = cur.next;
        cur.next = node;
}

3.3.2.查找元素結(jié)點

查找一個元素,返回對應(yīng)的下標(biāo)值。

 public ListNode findIndex(int index) {
        ListNode cur = head;
        while (index - 1 != 0) {
            cur = cur.next;
            index--;
        }
        return cur;//index-1位置的節(jié)點
    }

3.3.3.刪除元素結(jié)點

先找到對應(yīng)的下標(biāo)值,然后進(jìn)行刪除。刪除方法,前一個結(jié)點連接到刪除結(jié)點的后一個結(jié)點。

 如圖,先斷開d2與d3的連接,然后d2直接連接d4

代碼實現(xiàn):

//刪除第一次出現(xiàn)關(guān)鍵字為key的節(jié)點
    public void remove(int key){
        if(head == null) {
            return;
        }
        //當(dāng)刪除結(jié)點為頭結(jié)點
        if(head.val == key) {
            head = head.next;
            return;
        }
        ListNode prev = searchPrev(key); //返回待刪除結(jié)點的前一個結(jié)點
        if(prev == null) {
            System.out.println("沒有這個數(shù)據(jù)!");
            return;
        }
        ListNode del = prev.next;
        prev.next = del.next;
    }
    private ListNode searchPrev(int key) {
        ListNode prev = head;
        while (prev.next != null) {
            if(prev.next.val == key) {
                return prev;
            }else {
                prev = prev.next;
            }
        }
        return null;
    }

3.3.4.結(jié)點信息修改

修改指定下標(biāo)值的結(jié)點元素

public void searchPrev(int num,int date) {
        ListNode prev = head;
       for(int i=0;i<num-1;i++) {
                prev = prev.next;  
        }
        prev.val=date;
    }

四.LinkedList是什么?

LinkedList的底層是雙向鏈表結(jié)構(gòu),由于鏈表沒有將元素存儲在連續(xù)的空間中,元素存儲在單獨的節(jié)點中,然后通過引用將節(jié)點連接起來了,因此在在任意位置插入或者刪除元素時,不需要搬移元素,效率比較高。

 如圖所示:1. LinkedList實現(xiàn)了List接口

                   2. LinkedList的底層使用了雙向鏈表

                   3. LinkedList沒有實現(xiàn)RandomAccess接口,因此LinkedList不支持隨機訪問。

                  4. LinkedList的任意位置插入和刪除元素時效率比較高,時間復(fù)雜度為O(1)

                   5. LinkedList比較適合任意位置插入的場景

五.LinkedList使用方法

方法解釋
   構(gòu)造方法LinkedList()   無參構(gòu)造
public LinkedList(Collection<? extends E> c)使用其他集合容器中元素構(gòu)造List
常用方法boolean add(E e)尾插e
void add(int index,E element)將e插入到index位置
boolean addAII(Collection<? extends E> c)尾插c中的元素
E remove(int index)刪除index位置元素
boolean remove(Object o)刪除遇到的第一個o
E get( int index)獲取下標(biāo)index位置元素
void clear()清空

總結(jié)

到此這篇關(guān)于Java語言之LinkedList和鏈表的實現(xiàn)方法的文章就介紹到這了,更多相關(guān)Java LinkedList和鏈表實現(xiàn)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Web三大組件之Filter,Listener和Servlet詳解

    Web三大組件之Filter,Listener和Servlet詳解

    這篇文章主要為大家詳細(xì)介紹了Web三大組件之Filter,Listener和Servlet,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-03-03
  • IDEA2022版本創(chuàng)建maven?web項目的兩種方式詳解

    IDEA2022版本創(chuàng)建maven?web項目的兩種方式詳解

    創(chuàng)建maven?web項目有兩種方式,一種是使用骨架方式,一種是不使用骨架的方式,本文結(jié)合實例代碼給大家介紹了IDEA2022版本創(chuàng)建maven?web項目的兩種方式,需要的朋友可以參考下
    2023-02-02
  • 利用spring boot如何快速啟動一個web項目詳解

    利用spring boot如何快速啟動一個web項目詳解

    這篇文章主要給大家介紹了關(guān)于利用spring boot如何快速啟動一個web項目的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧、
    2017-12-12
  • AbstractQueuedSynchronizer內(nèi)部類Node使用講解

    AbstractQueuedSynchronizer內(nèi)部類Node使用講解

    這篇文章主要為大家介紹了AbstractQueuedSynchronizer內(nèi)部類Node使用講解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-07-07
  • 淺談java類和對象

    淺談java類和對象

    這篇文章主要介紹了淺談java類和對象,對于面向?qū)ο蟮拈_發(fā)來講也分為三個過程:OOA(面向?qū)ο蠓治觯?、OOD(面向?qū)ο笤O(shè)計)、OOP(面向?qū)ο缶幊蹋?,本文給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2022-05-05
  • Spring Boot集成Druid數(shù)據(jù)庫連接池

    Spring Boot集成Druid數(shù)據(jù)庫連接池

    這篇文章主要介紹了Spring Boot集成Druid數(shù)據(jù)庫連接池,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-04-04
  • spring?boot集成smart-doc自動生成接口文檔詳解

    spring?boot集成smart-doc自動生成接口文檔詳解

    這篇文章主要介紹了spring?boot集成smart-doc自動生成接口文檔詳解,smart-doc是一款同時支持java?restful?api和Apache?Dubbo?rpc接口文檔生成的工具,smart-doc顛覆了傳統(tǒng)類似swagger這種大量采用注解侵入來生成文檔的實現(xiàn)方法
    2022-09-09
  • SpringBoot在接收參數(shù)的七種方式詳解

    SpringBoot在接收參數(shù)的七種方式詳解

    這篇文章主要介紹了SpringBoot在接收參數(shù)的七種方式詳解,隨著前后端的分離,接口方式開發(fā)成為普遍的開發(fā)形式,前端相對于后端來說,常用的接口傳參方式就一定要了解和熟悉,下面?我們梳理了常用的七種?Controller層接受參數(shù)的方式,需要的朋友可以參考下
    2023-10-10
  • Java 改造ayui表格組件實現(xiàn)多重排序

    Java 改造ayui表格組件實現(xiàn)多重排序

    layui 的表格組件目前只支持單列排序,在實際應(yīng)用中并不能很好的支撐我們的業(yè)務(wù)需求。今天一時手癢,決定改造一番以支持多重排序。
    2021-04-04
  • mybatis 逆向生成后遵循java駝峰法則的解決

    mybatis 逆向生成后遵循java駝峰法則的解決

    這篇文章主要介紹了mybatis 逆向生成后遵循java駝峰法則的解決,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-11-11

最新評論