將兩個有序鏈表合並為一個新的有序鏈表並返回。新鏈表是通過拼接給定的兩個鏈表的所有節點組成的。
示例:
輸入:1->2->4, 1->3->4
輸出:1->1->2->3->4->4
兩個有序鏈表的排序,實際上可以看成一個單鏈表使用歸並排序的最后一個環節:“將兩個排好序的子序列合並為一個子序列:每次都是從未比較的兩個子序列的最小值中選出一個更小值”。
/** * Definition for singly-linked list. * public class ListNode { * int val;//當前節點的值 * ListNode next;//下一個節點的引用值 * ListNode(int x) { val = x; } * } */ class Solution { public ListNode mergeTwoLists(ListNode l1, ListNode l2) { ListNode temp=new ListNode(0); ListNode head=temp;//保留頭節點的引用 while(l1!=null&&l2!=null){ if(l1.val<l2.val) { temp.next=l1; l1=l1.next; } else { temp.next=l2; l2=l2.next; } temp=temp.next; } if(l1==null) temp.next=l2;//l1子序列為空,則直接拼屆l2 if(l2==null) temp.next=l1; return head.next;//返回頭節點指向的序列 } }