Neo's Blog

不抽象就无法深入思考
不还原就看不到本来面目!

0%

链表系列-有序链表合并

有序链表合并-题目描述

输入两个递增排序的链表,合并这两个链表并使新链表中的结点仍然是按照递增排序的。

样例
输入:1->3->5 , 2->4->5

输出:1->2->3->4->5->5

二叉树子结构-总体思路

考察点:链表上的归并排序

二叉树子结构-代码实现

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
/**
* Definition for singly-linked list.
* struct ListNode {
* int val;
* ListNode *next;
* ListNode(int x) : val(x), next(NULL) {}
* };
*/
class Solution {
public:
ListNode* merge(ListNode* l1, ListNode* l2) {
//dummy是一个哨兵节点,用来简化后续的判定是否为空逻辑
auto dummy = new ListNode(-1);
auto tail = dummy;
while (l1 && l2){
if (l1->val <= l2->val) {
tail = tail->next = new ListNode(l1->val); //追加一个新的node
l1 = l1->next; //往后移动一个元素
}
else {
tail = tail->next = new ListNode(l2->val);
l2 = l2->next;
}
}

//遍历剩下
while (l1) {
tail = tail->next = new ListNode(l1->val);
l1 = l1->next;
}
while (l2) {
tail = tail->next = new ListNode(l2->val);
l2 = l2->next;
}

return dummy->next;
}
};
你的支持是我坚持的最大动力!