题目描述

本题难度程度为简单,因此我们直接上解法
C++解法
/**
* Definition for singly-linked list.
* struct ListNode {
* int val;
* ListNode *next;
* ListNode(int x) : val(x), next(NULL) {}
* };
*/
class Solution {
public:
ListNode* mergeTwoLists(ListNode* l1, ListNode* l2) {
ListNode* p=l1;
ListNode* q=l2;
ListNode* result=new ListNode(0);
ListNode* r=result;
while(p&&q){
if(q->val>p->val){
r->next=p;
r=r->next;
p=p->next;
}else{
r->next=q;
r=r->next;
q=q->next;
}
}
if(q)
r->next=q;
if(p)
r->next=p;
return result->next;
}
};

本文详细解析了如何使用C++实现两个有序链表的合并算法。通过实例代码展示了算法的具体实现过程,包括初始化、比较节点值、连接节点以及返回结果等关键步骤。适合初学者理解和掌握链表操作的基础算法。
924

被折叠的 条评论
为什么被折叠?



