leetcode合並兩個有序鏈表Java實現


將兩個有序鏈表合並為一個新的有序鏈表並返回。新鏈表是通過拼接給定的兩個鏈表的所有節點組成的。 

示例:

輸入: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;//返回頭節點指向的序列
    }
}

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM