前言
问题描述:
- 输入两个递增的链表,单个链表的长度为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},转换过程如下图所示:
![在这里插入图片描述](https://img-blog.csdnimg.cn/534e9a1da112432e8ede08ca5067f305.png#pic_left)
- 或输入{-1,2,4},{1,3,4}时,合并后的链表为{-1,1,2,3,4,4},所以对应的输出为{-1,1,2,3,4,4},转换过程如下图所示:
![在这里插入图片描述](https://img-blog.csdnimg.cn/d5aa83759b3b4366a78a5574d55261ab.png#pic_left)
举例:
{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;
}
结束语