public class Solution {
public ListNode Merge(ListNode list1,ListNode list2) {
if(list1==null)return list2;
if(list2==null)return list1;
ListNode mergehead=null;
ListNode curr=mergehead;
while(list1!=null&&list2!=null){
if(list1.val<=list2.val){
if(mergehead==null){mergehead=curr=list1;}//第一次插入 头结点当前节点同时赋值
else{curr.next=list1;//不是第一次插入
curr=curr.next;}
list1=list1.next;
}else{
if(mergehead==null){mergehead=curr=list2;}//第一次插入 头结点当前节点同时赋值
else{curr.next=list2;//不是第一次插入
curr=curr.next;}
list2=list2.next;
}
if(list1==null){ //list1已经全部被插入 只有list2有剩余
curr.next=list2;
}
if(list2==null){
curr.next=list1;
}
}
return mergehead;
}
}