leetcode合并有序链表

合并有序链表

题目链接:![https://leetcode.cn/problems/merge-two-sorted-lists/\]

有两种方法求解该题目:

  • 非递归方法
  • 递归方法

非递归方法

使用非递归方法,关键在于记录已经合并好的链表的尾指针。

cpp 复制代码
ListNode* mergeTwoLists(ListNode* list1, ListNode* list2) {
	if (list1 == nullptr)
		return list2;
	else if (list2 == nullptr)
		return list1;

	ListNode* p = list1;
	ListNode* q = list2;
	ListNode* head; //已经合并好的链表的表头
	ListNode* r = new ListNode(); //已经合并好的链表的表尾
	head = r;

	while (p && q)
	{
		if (p->val < q->val)
		{
			r->next = p;
			p = p->next;
		}
		else
		{
			r->next = q;
			q = q->next;
		}

		r = r->next;
	}

	if (p == nullptr)
		r->next = q;
	else
		r->next = p;

	return head->next;
}

这里使用了哨兵节点,用于统一头部数据的比较,这使我们不需要对两个链表的头节点进行特殊处理,可以直接在循环中处理。

递归方法

c 复制代码
struct ListNode* mergeTwoLists(struct ListNode* l1, struct ListNode* l2) {
    if(l1==NULL)
        return l2;
    if(l2==NULL)
        return l1;
    if(l1->val < l2->val){
        l1->next = mergeTwoLists(l1->next,l2);
        return l1;
    }else{
        l2->next = mergeTwoLists(l1,l2->next);
        return l2;
    }
}
相关推荐
_深海凉_24 分钟前
LeetCode热题100- 字母异位词分组
leetcode
洛水水26 分钟前
【力扣100题】14.两数相加
c++·算法·leetcode
float_com29 分钟前
LeetCode80. 删除有序数组中的重复项 II
leetcode
pwn蒸鱼30 分钟前
leetcode:21. 合并两个有序链表
算法·leetcode·链表
洛水水31 分钟前
【力扣100题】15.删除链表的倒数第 N 个结点
算法·leetcode·链表
不爱吃炸鸡柳44 分钟前
6道经典算法题详解:从排序到链表,覆盖面试高频考点
算法·链表·面试
wfbcg1 小时前
每日算法练习:LeetCode 3. 无重复字符的最长子串 ✅
算法·leetcode·职场和发展
_日拱一卒1 小时前
LeetCode:矩阵置零
java·数据结构·线性代数·算法·leetcode·职场和发展·矩阵
穿条秋裤到处跑1 小时前
每日一道leetcode(2026.04.10):三个相等元素之间的最小距离 I
算法·leetcode
玛丽莲茼蒿1 小时前
Leetcode hot100 【中等】括号生成
算法·leetcode·职场和发展