AcWing 36. 合并两个排序的链表
宋标 Lv5

题目

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

数据范围

链表长度

样例

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

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

题解

思路: 因为两个链表都是单调递增, 开辟一个新链表,两个链表进行比较,
新链表next指向两个链表比较的最小值, 最小值的链表往后移动,最大值链表不动

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
/**
* 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) {
auto *res = new ListNode(-1);
auto *head = res;
while (l1 && l2)
{
bool f = l1 -> val < l2 -> val;
res = res -> next = f ? l1 : l2;
if (f) l1 = l1 -> next;
else l2 = l2 -> next;
}
auto *t = l1 ? l1 : l2;
while (t)
{
res = res -> next = t;
t = t -> next;
}
return head -> next;
}

};
 评论