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

Java有序鏈表的合并實現(xiàn)方法

 更新時間:2023年04月13日 10:06:51   作者:ziop-三月  
這篇文章主要通過兩個例題為大家介紹一下Java合并兩個及以上有序鏈表的實現(xiàn)方法,文中的示例代碼講解詳細,具有一定的學(xué)習(xí)價值,需要的可以參考一下

問題

將兩個升序鏈表合并為一個新的升序鏈表并返回。新鏈表是通過拼接給定的兩個鏈表的所有節(jié)點組成的。

示例 1:

輸入:l1 = [1,2,4], l2 = [1,3,4]
輸出:[1,1,2,3,4,4]

示例二:

<strong>輸入:</strong>l1 = [], l2 = []
<strong>輸出:</strong>[]

示例 3:

輸入:l1 = [], l2 = [0]
輸出:[0]

思路

版本一

  • 新建一個空的鏈表 nList
  • 在兩個鏈表(l1,l2)都不為空的情況下,比較兩個鏈表的第一個元素的值的大小,取出最小的加入到新鏈表當(dāng)中,然后小鏈表的頭指針指向下一位,并且nList的指針也指向下一位
  • 如果兩個鏈表還都不為空,繼續(xù)循環(huán)
  • 如果兩個鏈表有一個為空,那么將不為空的鏈表拼接到nList后邊
  • 最后返回 nList 的next 作為新鏈表的頭結(jié)點

版本二

  • 首先判斷兩個鏈表是否為空,為空直接返回空鏈表。不為空的繼續(xù)向下走
  • 判斷 l1 和 l2的頭結(jié)點誰更小,則將這個節(jié)點保存為頭結(jié)點,后邊的節(jié)點一次拼接在該節(jié)點上邊。
  • 后邊思路同版本一

答案

版本一

新建一個節(jié)點,將原來的鏈表都傳到新的鏈表當(dāng)中

public ListNode mergeTwoLists(ListNode list1, ListNode list2) {
    ListNode head = new ListNode(-1);
    ListNode   = head;
    while (list1 != null && list2 != null) {
        boolean b = list1.val <= list2.val;
        all.next = b ? list1 : list2;
        if (b) list1 = list1.next;
        else list2 = list2.next;
        all = all.next;
    }
    all.next = list1 != null ? list1 : list2;
    return head.next;
}

版本二

從原來的鏈表中選擇出來一個進行整合,不適用任何新的內(nèi)存

public ListNode mergeTwoLists(ListNode list1, ListNode list2) {
    if (list1 == null || list2 == null) {
        return list1 == null ? list2 : list1;
    }
    ListNode head = list1.val <= list2.val ? list1 : list2;
    if (list1.val <= list2.val)
        list1 = list1.next;
    else
        list2 = list2.next;
    ListNode tmp = head;
    while (list1 != null && list2 != null) {
        boolean b = list1.val <= list2.val;
        tmp.next = b ? list1 : list2;
        if (b) list1 = list1.next;
        else list2 = list2.next;
        tmp = tmp.next;
    }
    tmp.next = list1 != null ? list1 : list2;
    return head;
}

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

相關(guān)文章

  • JDK動態(tài)代理提高代碼可維護性和復(fù)用性利器

    JDK動態(tài)代理提高代碼可維護性和復(fù)用性利器

    這篇文章主要為大家介紹了JDK動態(tài)代理提高代碼可維護性和復(fù)用性利器,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-10-10
  • 解決 java.lang.NoSuchMethodError的錯誤

    解決 java.lang.NoSuchMethodError的錯誤

    這篇文章主要介紹了解決 java.lang.NoSuchMethodError的錯誤的相關(guān)資料,需要的朋友可以參考下
    2017-06-06
  • 使用spring-boot-admin對spring-boot服務(wù)進行監(jiān)控的實現(xiàn)方法

    使用spring-boot-admin對spring-boot服務(wù)進行監(jiān)控的實現(xiàn)方法

    這篇文章主要介紹了使用spring-boot-admin對spring-boot服務(wù)進行監(jiān)控的實現(xiàn)方法,需要的朋友可以參考下
    2018-02-02
  • 深入解析Java中的JDBC事務(wù)

    深入解析Java中的JDBC事務(wù)

    這篇文章主要介紹了深入解析Java中的JDBC事務(wù),包含了Java多線程的事務(wù)并發(fā)等知識,需要的朋友可以參考下
    2015-08-08
  • 詳解Java如何簡化條件表達式

    詳解Java如何簡化條件表達式

    在復(fù)雜的實際業(yè)務(wù)中,往往會出現(xiàn)各種嵌套的條件判斷邏輯。隨著需求的增加,條件邏輯會變得越來越復(fù)雜。面對這種情況,簡化判斷邏輯就是不得不做的事情,下面為大家介紹幾種方法
    2022-06-06
  • SpringBoot+Echarts實現(xiàn)請求后臺數(shù)據(jù)顯示餅狀圖

    SpringBoot+Echarts實現(xiàn)請求后臺數(shù)據(jù)顯示餅狀圖

    這篇文章主要介紹了SpringBoot+Echarts實現(xiàn)請求后臺數(shù)據(jù)顯示餅狀圖,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-12-12
  • Java中IO流文件讀取、寫入和復(fù)制的實例

    Java中IO流文件讀取、寫入和復(fù)制的實例

    下面小編就為大家?guī)硪黄狫ava中IO流文件讀取、寫入和復(fù)制的實例。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-10-10
  • MyBatis高級映射ResultMap解決屬性問題

    MyBatis高級映射ResultMap解決屬性問題

    對于數(shù)據(jù)庫中對表的增刪改查操作,我們知道增刪改都涉及的是單表,而只有查詢操作既可以設(shè)計到單表操作又可以涉及到多表操作,所以對于輸入映射parameterType而言是沒有所謂的高級映射的,也就是說高級映射只針對于輸出映射
    2023-02-02
  • java @Value(

    java @Value(

    這篇文章主要介紹了java @Value("${}")獲取不到配置文件中值的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-08-08
  • Java動態(tài)調(diào)用類中方法代碼

    Java動態(tài)調(diào)用類中方法代碼

    這篇文章主要介紹了Java動態(tài)調(diào)用類中方法代碼,需要的朋友可以參考下
    2014-02-02

最新評論