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;
    }
}
相关推荐
澈2073 小时前
C++ list容器完全指南
数据结构·c++·链表
承渊政道4 小时前
【动态规划算法】(完全背包问题从状态定义到空间优化)
数据结构·c++·学习·算法·leetcode·动态规划·哈希算法
超级大福宝5 小时前
【力扣48. 旋转图像】超好记忆版 + 口诀
c++·算法·leetcode
人道领域5 小时前
【LeetCode刷题日记】掌握二叉树遍历:栈实现的三种绝妙方法
算法·leetcode·职场和发展
阿Y加油吧5 小时前
二刷 LeetCode:动态规划经典双题复盘
算法·leetcode·动态规划
莫等闲-6 小时前
代码随想录一刷记录Day44——leetcode1143.最长公共子序列 53. 最大子序和
数据结构·c++·算法·leetcode·动态规划
承渊政道6 小时前
【动态规划算法】(背包问题经典模型与解题套路)
数据结构·c++·学习·算法·leetcode·动态规划·哈希算法
m0_629494738 小时前
LeetCode 热题 100-----18.矩阵置零
数据结构·leetcode·矩阵
阿Y加油吧8 小时前
二刷 LeetCode:两道经典贪心题复盘
算法·leetcode·职场和发展
Java成神之路-8 小时前
【LeetCode 刷题笔记】35. 搜索插入位置 | 二分查找经典入门题
算法·leetcode