LeetCode-021 合并两个有序链表

将两个升序链表合并为一个新的 升序 链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。

示例:

输入:1->2->4, 1->3->4
输出:1->1->2->3->4->4

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/merge-two-sorted-lists

解题思路

循环:当两个链表节点都不为空时, 找出较小的一个拼接到新链表
当其中一个链表节点为空时, 将新链表的当前节点的next指向另一节点, 就能将剩余节点全部拼接上

代码

class Solution {
    public ListNode mergeTwoLists(ListNode l1, ListNode l2) {
        // 定义一个节点
        ListNode head = new ListNode(-1);
        ListNode cur = head;
        // 当两个链表节点都不为空时
        while (l1 != null && l2 != null) {
            // 找出较小的一个节点, 拼接到cur
            if (l1.val <= l2.val) {
                cur.next = l1;
                // 迭代
                l1 = l1.next;
            } else {
                cur.next = l2;
                l2 = l2.next;
            }
            // 迭代
            cur = cur.next;
        }
        // 将剩余节点拼上
        cur.next = l1 != null ? l1 : l2;
        // head的下一个节点才是我们要的新链表的头节点
        return head.next;
    }
}

你可能感兴趣的:(LeetCode-021 合并两个有序链表)