您好,登錄后才能下訂單哦!
這篇文章將為大家詳細講解有關LeetCode如何合并兩個有序鏈表,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
將兩個升序鏈表合并為一個新的升序鏈表并返回,新鏈表是通過拼接給定的兩個鏈表的所有節點組成的,比如:
使用循環迭代的方法,依次找出較小的節點鏈接起來即可:
class Solution {
public:
ListNode* mergeTwoLists(ListNode* l1, ListNode* l2) {
// 1. 升序鏈表 l3
ListNode *l3 = new ListNode(0);
// 2. 保存頭指針用于返回結果
ListNode *head = l3;
while (l1 && l2) {
// 3. 選擇較小的節點連接到 l3 尾部
if (l1->val <= l2->val) {
l3->next = l1;
l1 = l1->next;
} else {
l3->next = l2;
l2 = l2->next;
}
l3 = l3->next;
}
// 將多余的 l1 或者 l2 節點直接鏈接到 l3 尾部
l3->next = (l1 == nullptr ? l2 : l1);
return head->next;
}
};
遞歸法要注意遞歸表達式和循環結束條件:
遞歸法不是很好理解,建議用 vs 調試看下內存。
class Solution {
public:
ListNode* mergeTwoLists(ListNode* l1, ListNode* l2) {
// 1. 遞歸結束條件
if (l1 == nullptr)
return l2;
// 2. 遞歸結束條件
if (l2 == nullptr)
return l1;
// 3. 遞歸表達式
if (l1->val <= l2->val) {
l1->next = mergeTwoLists(l1->next, l2);
return l1;
} else {
l2->next = mergeTwoLists(l1, l2->next);
return l2;
}
}
};
關于“LeetCode如何合并兩個有序鏈表”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。