个人主页:元清加油_【C++】,【C语言】,【数据结构与算法】-CSDN博客
个人专栏:http://t.csdnimg.cn/ZxuNL
http://t.csdnimg.cn/c9twt
前言:这个专栏主要讲述递归递归、搜索与回溯算法,所以下面题目主要也是这些算法做的
我讲述题目会把讲解部分分为3个部分:
1、题目解析
2、算法原理思路讲解
3、代码实现
一、合并两个有序链表
题目链接:力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台
题目:
将两个升序链表合并为一个新的 升序 链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。
示例 1:
输入:l1 = [1,2,4], l2 = [1,3,4] 输出:[1,1,2,3,4,4]
示例 2:
输入:l1 = [], l2 = [] 输出:[]
示例 3:
输入:l1 = [], l2 = [0] 输出:[0]
提示:
- 两个链表的节点数目范围是
[0, 50]
-100 <= Node.val <= 100
l1
和l2
均按 非递减顺序 排列
二、解法
题目解析
根据题目意思:
将两个升序链表合并为一个新的 升序 链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。
说明我们不能直接去新建一个链表,我们只能直接改变旧链表的指向来合并成一个新的链表
算法原理思路讲解
注意:我们在做递归这一类题目是要将递归看作一个黑盒,我们不管他是如何实现的,我们就相信他一定可以帮助我们完成目标
如何去写一个递归
1、先找到相同的子问题 函数头的设计
2、只关心某一个子问题是如何解决的 函数体的书写
3、注意一下递归函数的出口 终止条件
ListNode* dfs(ListNode* l1, ListNode* l2)
1、比较两个链表的头结点值的大小(如果l1小)2、l1->next = dfs(l1->next,l2);3、返回合并后的头结点,也就是l1
if (l1->val <= l2->val)
{
l1->next = dfs(l1->next,l2);
return l1;
}
代码实现:
class Solution
{
public:
ListNode* dfs(ListNode* l1, ListNode* l2)
{
if ( l1 == nullptr) return l2;
if ( l2 == nullptr) return l1;
if (l1->val <= l2->val)
{
l1->next = dfs(l1->next,l2);
return l1;
}
else
{
l2->next = dfs(l1,l2->next);
return l2;
}
}
ListNode* mergeTwoLists(ListNode* list1, ListNode* list2)
{
return dfs(list1,list2);
}
};