leetcode面の質問 - 25面接の質問の組み合わせ2つのソートリスト

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;
    }
}
リリース元の2件の記事 ウォンの賞賛0 ビュー11

おすすめ

転載: blog.csdn.net/qq_40860196/article/details/104696226