前言
问题描述:
- 输入两个递增的链表,单个链表的长度为n,合并这两个链表并使新链表中的节点仍然是递增排序的。
数据范围:0≤n≤1000,-1000 \le 节点值0≤节点值≤1000 - 要求:空间复杂度 O(1),时间复杂度 O(n)
- 如输入{1,3,5},{2,4,6}时,合并后的链表为{1,2,3,4,5,6},所以对应的输出为{1,2,3,4,5,6},转换过程如下图所示:

- 或输入{-1,2,4},{1,3,4}时,合并后的链表为{-1,1,2,3,4,4},所以对应的输出为{-1,1,2,3,4,4},转换过程如下图所示:

举例:
{1,3,5},{2,4,6}
{1,2,3,4,5,6}
{},{}
{}
{-1,2,4},{1,3,4}
{-1,1,2,3,4,4}
解法思路:
- 由于输入的两个递增的链表,则无需对各自进行排序,只需从各自第一个数据开始,取较小的往新链表内存放即可。
代码结果:
struct ListNode* Merge(struct ListNode* pHead1, struct ListNode* pHead2 )
{
struct ListNode* vhead = (struct ListNode*)malloc(sizeof(struct ListNode));
vhead->val = -1;
struct ListNode *p = vhead;
while (pHead1 && pHead2)
{
if (pHead1->val <= pHead2->val)
{
p->next = pHead1;
pHead1 = pHead1->next;
}
else {
p->next = pHead2;
pHead2 = pHead2->next;
}
p = p->next;
}
p->next = pHead1 ? pHead1 : pHead2;
return vhead->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
- 32
- 33
结束语