您好,登錄后才能下訂單哦!
小編給大家分享一下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如何實現合并兩個有序鏈表”有了一定的了解,如果想了解更多相關知識,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。