JZ-016-合併兩個排序的連結串列

雄獅虎豹發表於2021-12-11

合併兩個排序的連結串列

題目描述

輸入兩個單調遞增的連結串列,輸出兩個連結串列合成後的連結串列,當然我們需要合成後的連結串列滿足單調不減規則。

題目連結: 合併兩個排序的連結串列

程式碼

/**
 * 標題:合併兩個排序的連結串列
 * 題目描述
 * 輸入兩個單調遞增的連結串列,輸出兩個連結串列合成後的連結串列,當然我們需要合成後的連結串列滿足單調不減規則。
 * 題目連結:
 * https://www.nowcoder.com/practice/d8b6b4358f774294a89de2a6ac4d9337?tpId=13&&tqId=11169&rp=1&ru=/ta/coding-interviews&qru=/ta/coding-interviews/question-ranking
 */
public class Jz16 {
  
    public ListNode merge(ListNode list1, ListNode list2) {
        if (list1 == null && list2 == null) {
            return null;
        }
        if (list1 == null) {
            return list2;
        }
        if (list2 == null) {
            return list1;
        }
        ListNode result = new ListNode(-1);
        ListNode next = result;
        while (list1 != null || list2 != null) {
            if (list1 == null) {
                next.next = list2;
                break;
            } else if (list2 == null) {
                next.next = list1;
                break;
            } else if (list1.val < list2.val) {
                next.next = list1;
                list1 = list1.next;
            } else {
                next.next = list2;
                list2 = list2.next;
            }
            next = next.next;
        }

        return result.next;
    }

    public static void main(String[] args) {
        ListNode list1 = new ListNode(1);
        list1.next = new ListNode(3);
        list1.next.next = new ListNode(5);

        ListNode list2 = new ListNode(2);
        list2.next = new ListNode(4);
        list2.next.next = new ListNode(6);

        System.out.println("after merge");
        Jz16 jz16 = new Jz16();
        ListNode result = jz16.merge(list1, list2);
        ListNode cur = result;
        while (cur != null) {
            System.out.print(cur.val + " ");
            cur = cur.next;
        }
    }
}
【每日寄語】 無論別人怎麼看,我絕不打亂自己的節奏。喜歡的事自然可以堅持。

相關文章