21. 合并两个有序链表c++

将两个有序链表合并为一个新的有序链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。 

示例:

输入:1->2->4, 1->3->4
输出:1->1->2->3->4->4

应该有两种思路,递归,迭代

递归如下:每次比较头大小,return 头小的节点指向(递归函数)(头小节点->next链,另一个链) 某一个链空了,直接return另一条链就可以了;

class Solution {
public:
    ListNode* mergeTwoLists(ListNode* l1, ListNode* l2) {
        if(l1==NULL) return l2;
        if(l2==NULL) return l1;
        if(l1->val<l2->val){
            l1->next=mergeTwoLists(l1->next,l2);
            return l1;
        }
        else {
            l2->next=mergeTwoLists(l1,l2->next);
            return l2;
        }
    }
};

猜你喜欢

转载自blog.csdn.net/HeXiQuan123/article/details/82421998
今日推荐