题目描述
合并两个排序的链表
输入两个单调递增的链表,输出两个链表合成后的链表,当然我们需要合成后的链表满足单调不减规则。
分析
思路一:新建一个链表,将两个链表的值按照大小顺序复制到新链表中。
源码
思路一
/*
struct ListNode {
int val;
struct ListNode *next;
ListNode(int x) :
val(x), next(NULL) {
}
};*/
class Solution {
public:
ListNode* Merge(ListNode* pHead1, ListNode* pHead2)
{
if(pHead1 == NULL ) return pHead2;
if(pHead2 == NULL ) return pHead1;
ListNode* p1,*p2;
p1 = pHead1; //p1指向链表1
p2 = pHead2; //p2指向链表2
ListNode* reshead = new ListNode(0);//创立空头节点,其next指向新链表的头指针。
ListNode* ptemp = reshead;
while(p1 != NULL && p2!= NULL)
{
int val;
ListNode* newnode = new ListNode(0);
if(p1->val<=p2->val)
{
newnode->val = p1->val;
p1 = p1->next;
}
else
{
newnode->val = p2->val;
p2 = p2->next;
}
ptemp->next = newnode;
ptemp = ptemp->next;
}
while(p1!=NULL)
{
ListNode* newnode = new ListNode(0);
newnode->val = p1->val;
ptemp->next = newnode;
ptemp = ptemp->next;
p1 = p1->next;
}
while(p2!=NULL)
{
ListNode* newnode = new ListNode(0);
newnode->val = p2->val;
ptemp->next = newnode;
ptemp = ptemp->next;
p2 = p2->next;
}
return reshead->next;
}
};