Skip to content

Latest commit

 

History

History
109 lines (99 loc) · 3.4 KB

File metadata and controls

109 lines (99 loc) · 3.4 KB

21. 合并两个有序链表

https://leetcode-cn.com/problems/merge-two-sorted-lists/

Video

<iframe width="100%" height="600" src="//player.bilibili.com/player.html?aid=201593594&bvid=BV1Ph411d7E2&cid=217311945&page=1&as_wide=1&high_quality=1" scrolling="no" border="0" frameborder="no" framespacing="0" allowfullscreen="true"> </iframe>

Java

/*
 * @Author: Goog Tech
 * @Date: 2020-07-27 18:38:24
 * @Description: https://leetcode-cn.com/problems/merge-two-sorted-lists/
 * @FilePath: \leetcode-googtech\#102. Binary Tree Level Order Traversal\21.合并两个有序链表.java
 */ 

/*
 * @lc app=leetcode.cn id=21 lang=java
 *
 * [21] 合并两个有序链表
 */

// @lc code=start
/**
 * Definition for singly-linked list.
 * public class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode() {}
 *     ListNode(int val) { this.val = val; }
 *     ListNode(int val, ListNode next) { this.val = val; this.next = next; }
 * }
 */
class Solution {
    // 迭代法
    public ListNode mergeTwoLists(ListNode l1, ListNode l2) {
        // 判断链表是否为空
        if(l1 == null) return l2;
        if(l2 == null) return l1;
        // 初始化哨兵节点与其头指针
        ListNode preHead = new ListNode(-1);
        ListNode currentNode = preHead;
        // 遍历链表并逐个比较两节点大小,通过移动哨兵节点头指针来构建新链表
        while(l1 != null && l2 != null) {
            if(l1.val >= l2.val) {
                currentNode.next = l2;
                l2 = l2.next;
            }else {
                currentNode.next = l1;
                l1 = l1.next;
            }
            // 每比较一次,哨兵头指针都需要往后移动一位
            currentNode = currentNode.next;
        }
        //l1与l2合并结束后,最多还剩一个链表是非空的,这时需将链表末尾指向未合并完的链表
        currentNode.next = l2 == null ? l1 : l2;
        return preHead.next;
    }
}

// @lc code=end

Python

'''
@Author: Goog Tech
@Date: 2020-07-27 18:37:11
@Description: https://leetcode-cn.com/problems/merge-two-sorted-lists/
@FilePath: \leetcode-googtech\#102. Binary Tree Level Order Traversal\21.合并两个有序链表.py
'''

#
# @lc app=leetcode.cn id=21 lang=python
#
# [21] 合并两个有序链表
#

# @lc code=start
# Definition for singly-linked list.
# class ListNode(object):
#     def __init__(self, val=0, next=None):
#         self.val = val
#         self.next = next
class Solution(object):
    # 迭代法
    def mergeTwoLists(self, l1, l2):
        """
        :type l1: ListNode
        :type l2: ListNode
        :rtype: ListNode
        """
        # 判断链表是否为空
        if not l1 or not l2: return l2 or l1
        # 初始化哨兵节点与其头指针
        preHead = ListNode(-1)
        currentNode = preHead
        # 遍历链表并逐个比较两个节点大小,通过移动哨兵节点指针来构建新链表
        while l1 and l2:
            if l1.val >= l2.val: currentNode.next, l2 = l2, l2.next
            else: currentNode.next, l1 = l1, l1.next
            # 每比较一次,哨兵头指针都需要往后移动一位
            currentNode = currentNode.next
        #l1与l2合并结束后,最多还剩一个链表是非空的,这时需将链表末尾指向未合并完的链表
        currentNode.next = l2 if l2 is not None else l1
        return preHead.next

# @lc code=end