91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

java和java如何實現合并兩個有序鏈表

發布時間:2022-01-17 11:39:59 來源:億速云 閱讀:155 作者:小新 欄目:大數據

小編給大家分享一下java和java如何實現合并兩個有序鏈表,希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!


 

題目描述

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

示例:

輸入:1->2->4, 1->3->4
輸出:1->1->2->3->4->4
   

解題方案

 

思路

  • 標簽:鏈表、遞歸

  • 這道題可以使用遞歸實現,新鏈表也不需要構造新節點,恰好是文章套路解決遞歸問題的極好驗證,我們下面列舉遞歸三個要素

  • 終止條件:兩條鏈表分別名為l1和l2,當l1為空或l2為空時結束

  • 返回值:每一層調用都返回排序好的鏈表頭

  • 本級遞歸內容:如果l1的val值更小,則將l1.next與排序好的鏈表頭相接,l2同理

  • O(m+n),m為l1的長度,n為l2的長度

 

代碼

  • Java版本

/**
* Definition for singly-linked list.
* public class ListNode {
*     int val;
*     ListNode next;
*     ListNode(int x) { val = x; }
* }
*/
class Solution {
   public ListNode mergeTwoLists(ListNode l1, ListNode l2) {
       if(l1 == null) {
           return l2;
       }
       if(l2 == null) {
           return l1;
       }

       if(l1.val < l2.val) {
           l1.next = mergeTwoLists(l1.next, l2);
           return l1;
       } else {
           l2.next = mergeTwoLists(l1, l2.next);
           return l2;
       }
   }
}
 
  • JavaScript版本

/**
* Definition for singly-linked list.
* function ListNode(val) {
*     this.val = val;
*     this.next = null;
* }
*/
/**
* @param {ListNode} l1
* @param {ListNode} l2
* @return {ListNode}
*/
var mergeTwoLists = function(l1, l2) {
   if(l1 === null){
       return l2;
   }
   if(l2 === null){
       return l1;
   }
   if(l1.val < l2.val){
       l1.next = mergeTwoLists(l1.next, l2);
       return l1;
   }else{
       l2.next = mergeTwoLists(l1, l2.next);
       return l2;
   }
};

看完了這篇文章,相信你對“java和java如何實現合并兩個有序鏈表”有了一定的了解,如果想了解更多相關知識,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

城固县| 屯留县| 宁河县| 江达县| 孟连| 巍山| 靖西县| 灌南县| 门头沟区| 尖扎县| 夏邑县| 中山市| 金湖县| 运城市| 宁南县| 松阳县| 科技| 瓦房店市| 昭通市| 清原| 安福县| 疏附县| 通州市| 甘南县| 鄂州市| 东莞市| 三穗县| 本溪市| 桐乡市| 涡阳县| 永泰县| 彰武县| 湾仔区| 新竹市| 息烽县| 思南县| 吉安县| 大连市| 庄浪县| 建宁县| 陕西省|