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