LeetCode 21. 合并两个有序链表

题目链接

力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台

题目解析

定义一个哨兵位的头结点,然后遍历这两个链表将小的结点放前面。然后再判断这两个链表其中哪一个没有遍历完毕,然后将没有遍历完毕的那个接在后面。

代码

cpp 复制代码
/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode() : val(0), next(nullptr) {}
 *     ListNode(int x) : val(x), next(nullptr) {}
 *     ListNode(int x, ListNode *next) : val(x), next(next) {}
 * };
 */
class Solution 
{
public:
    ListNode* mergeTwoLists(ListNode* list1, ListNode* list2) 
    {
        // 哨兵位头结点
        ListNode* phead=new ListNode(-1);    

        ListNode* cur=phead;

        while(list1!=nullptr&&list2!=nullptr)
        {
            if(list1->val<=list2->val)
            {
                cur->next=list1;
                list1=list1->next;
            }
            else
            {
                cur->next=list2;
                list2=list2->next;
            }
            cur=cur->next;
        }
        if(list1!=nullptr) cur->next=list1;
        if(list2!=nullptr) cur->next=list2;

        return phead->next;
    }
};
相关推荐
程序员buddha1 小时前
C语言数组详解
c语言·开发语言·算法
蒙奇D索大3 小时前
【算法】递归算法的深度实践:从布尔运算到二叉树剪枝的DFS之旅
笔记·学习·算法·leetcode·深度优先·剪枝
卡提西亚3 小时前
C++笔记-25-函数模板
c++·笔记·算法
ghie90903 小时前
MATLAB/Simulink水箱水位控制系统实现
开发语言·算法·matlab
多多*4 小时前
分布式系统中的CAP理论和BASE理论
java·数据结构·算法·log4j·maven
yuan199974 小时前
基于粒子群优化(PSO)算法的PID控制器参数整定
算法
小白程序员成长日记4 小时前
2025.11.10 力扣每日一题
数据结构·算法·leetcode
hoiii1875 小时前
基于交替方向乘子法(ADMM)的RPCA MATLAB实现
人工智能·算法·matlab
fengfuyao9855 小时前
MATLAB的加权K-means(Warp-KMeans)聚类算法
算法·matlab·kmeans
循环过三天6 小时前
3.1、Python-列表
python·算法