LeetCodehot100-21 合并两个有序链表

复制代码
class Solution {
public:
    ListNode* mergeTwoLists(ListNode* list1, ListNode* list2) {
        if(list1==nullptr||list2==nullptr){
            return list1==nullptr?list2:list1;
        }
        ListNode* head=list1->val<=list2->val?list1:list2;
        ListNode* cur1=head->next;
        ListNode* cur2=head==list1?list2:list1;
        ListNode* tmp=head;
        while(cur1!=nullptr&&cur2!=nullptr){
            if(cur1->val<=cur2->val){
                tmp->next=cur1;
                cur1=cur1->next;
            }
            else{
                tmp->next=cur2;
                cur2=cur2->next;
            }
            tmp=tmp->next;
        }
        tmp->next=cur1==nullptr?cur2:cur1;
        return head;
    }
};

递归:

复制代码
class Solution {
public:
    ListNode* mergeTwoLists(ListNode* list1, ListNode* list2) {
        if(list1==nullptr) return list2;
        if(list2==nullptr) return list1;
        if(list1->val<=list2->val){
            list1->next=mergeTwoLists(list1->next,list2);//返回的后面的有序链表中的第一个点
            return list1;
        }
        else{
            list2->next=mergeTwoLists(list1,list2->next);
            return list2;
        }
    }
};
相关推荐
白羊by9 小时前
YOLOv1~v11 全版本核心演进总览
深度学习·算法·yolo
墨尘笔尖10 小时前
最大最小值降采样算法的优化
c++·算法
white-persist12 小时前
【vulhub shiro 漏洞复现】vulhub shiro CVE-2016-4437 Shiro反序列化漏洞复现详细分析解释
运维·服务器·网络·python·算法·安全·web安全
FL162386312913 小时前
基于C#winform部署软前景分割DAViD算法的onnx模型实现前景分割
开发语言·算法·c#
baizhigangqw13 小时前
启发式算法WebApp实验室:从搜索策略到群体智能的能力进阶
算法·启发式算法·web app
C雨后彩虹14 小时前
最多等和不相交连续子序列
java·数据结构·算法·华为·面试
cpp_250114 小时前
P2347 [NOIP 1996 提高组] 砝码称重
数据结构·c++·算法·题解·洛谷·noip·背包dp
Hugh-Yu-13012314 小时前
二元一次方程组求解器c++代码
开发语言·c++·算法
编程大师哥15 小时前
C++类和对象
开发语言·c++·算法
加农炮手Jinx15 小时前
LeetCode 146. LRU Cache 题解
算法·leetcode·力扣