LeetCode第21題

960 ワード

2つの順序付きチェーンテーブルを新しい順序付きチェーンテーブルに結合して返します.新しいチェーンテーブルは、指定された2つのチェーンテーブルのすべてのノードを接合することによって構成されます. 
例:
1->2->4, 1->3->4
1->1->2->3->4->4

構想:同時に2つのチェーンテーブルを遍歴し、2つのチェーンテーブルを比較する.値の小さいものを新しいチェーンテーブルに保存し、そのうちの1つのチェーンテーブルが比較されて空になった場合、別のチェーンテーブルの残りの値をすべて新しいチェーンテーブルに保存します.
  public ListNode mergeTwoLists(ListNode l1, ListNode l2) {
      ListNode head= new ListNode(0);
		ListNode cur = head;
		//  l1 l2        ,cur      
		while(l1 != null && l2 != null) {
			if(l1.val < l2.val) {
				cur.next = l1;
				l1 = l1.next;
                cur = cur.next;
			}
			else {
				cur.next = l2;
				l2 = l2.next;
                cur = cur.next;
			}	
		}
		
		//   l1 l2          
		if(l1 != null){
            cur.next=l1;
         
        }
		else {
            cur.next=l2;
            
        }
		
		return head.next;

	
    }