2つのソートされたリストをマージする25.面接の質問
、リストの2つの昇順を入力するために2つのリストをマージして、新しいノードのリストがまだの昇順です。
実施例1:
入力:1-> 2-> 4、1-> 3-> 4
出力:1-> 1-> 2-> 3-> 4-> 4つ
の制限:
0 <=鎖長<= 1000
解決アイデア:最初の仮想ノードを設定し、新たなデータリストを挿入し、二つのポインタと比較されたが小さい、次にポインタが移動され、また、新たなカレントポインタリストシフトした後、上記の動作が繰り返されます。最後に、動作の詳細。
/**
* 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 newNode = new ListNode(0);
ListNode cur = newNode;
while(l1 != null && l2 != null){
if(l1.val > l2.val)
{
cur.next = l2;
l2 = l2.next;
}else{
cur.next = l1;
l1 = l1.next;
}
cur = cur.next;
}
if(l1 != null){
cur.next = l1;
}
if(l2 != null){
cur.next = l2;
}
return newNode.next;
}
}