
老生常谈的问题,也没啥好说的;
归并排序而已;
具体代码:/**
* 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* ph=new ListNode(-1);
ListNode* head=ph;
while(list1||list2){
if(list1&&list2){
if(list1->val<list2->val){
head->next=list1;
list1=list1->next;
}else{
head->next=list2;
list2=list2->next;
}
head=head->next;
continue;
}
if(list1){
head->next=list1;
list1=list1->next;
}
if(list2){
head->next=list2;
list2=list2->next;
}
head=head->next;
}
return ph->next;
}
};
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)