题目描述
输入两个单调递增的链表,输出两个链表合成后的链表,当然我们需要合成后的链表满足单调不减规则。


思路1:用新链表

public class Solution {
    public ListNode Merge(ListNode list1,ListNode list2) {
        if (list1 == null) {
            return list2;
        }
        if (list2 == null) {
            return list1;
        }
        ListNode newList = new ListNode(-1);
        ListNode p3 = newList;
        while (list1 != null && list2 != null) {
            if (list1.val < list2.val) {
                p3.next = list1;
                list1 = list1.next;
            } else {
                p3.next = list2;
                list2 = list2.next;
            }
            p3 = p3.next;
        }

        while (list1 != null) {
            p3.next = list1;
            list1 = list1.next;
            p3 = p3.next;
        }
      //if (list1 != null)  {
      //   p3.next = list1;} 改进写法,不用一个个去复制

        while (list2 != null) {
            p3.next = list2;
            list2 = list2.next;
            p3 = p3.next;
        }
        return newList.next;
    }
}

思路2:不使用新链表,在原链表中插入

//向链表1中插入
public class Solution {
    public ListNode Merge(ListNode list1,ListNode list2) {
        if(list1 == null ){
            return list2;
        }
        if(list2 == null){
            return list1;
        } 
        if(list1 == null && list2 == null){
            return null;
        }
        ListNode list = null;  //list是要返回的头结点,因此这里比最小值,并插入给list1
        if (list1.val > list2.val) {
            list = list1;
            list1 = list2;
            list2 = list;
        }
        list = list1;
        ListNode p = null;  //p是为了记录list1的下一个节点,避免插入时链表断开
        while (list1.next != null && list2 != null) { 
            // list1.next!=null 而不是list1!=null
//这是因此之前不仅比较了最小值,还将最小值直接给了list1,因此从list1的第二个节点开始比
//如果仅比较大小后就赋值个list,而不进行其他处理,那这里就是list1和list2比较了。
            if (list1.next.val <= list2.val) {
                list1 = list1.next;
            } else {   //在A->C中插入B(list1是A)
                p = list1.next;      // 记录要插入的List1 A的下一个节点C
                list1.next = list2;  // 插入比较小的list2的某节点B 连上A和B
                list2 = list2.next;  //list2往下走一个节点,准备下一轮比较 
                list1 = list1.next;  //将当前节点由A变成刚刚连上的B
                list1.next = p;      //将当前节点(也就是新节点)B与之前的C连上
            }
        }
        if (list2 != null) { // 最后只关心list2不为空
            list1.next = list2;
        }
        return list;
    }
}

思路3:递归
如果list1小于list2,则list1作为新序列的开头,后面应该接的部分等同于list1.next和list2的重新排序。反之同理。因此从最开始,就没有确定一定是插入到List1或者List2,而且选择较小的。

public class Solution {
    public ListNode Merge(ListNode list1,ListNode list2) {
        if (list1 == null){
            return list2;
        }
        if (list2 == null){
            return list1;
        }
        if (list1.val<list2.val){
            list1.next = Merge(list1.next, list2);
            return list1; 
        }else {
            list2.next = Merge(list2.next, list1);
            return list2;
        }
    }
}