剑指 Offer 25. 合并两个排序的链表 | 刷题打卡

185 阅读1分钟

题目描述

leetcode链接:leetcode-cn.com/problems/he…

输入两个递增排序的链表,合并这两个链表并使新链表中的节点仍然是递增排序的。

示例1:

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

限制: 0 <= 链表长度 <= 1000

思路描述

AC代码

递归法:

/**
 * Definition for singly-linked list.
 * function ListNode(val) {
 *     this.val = val;
 *     this.next = null;
 * }
 */
/**
 * @param {ListNode} l1
 * @param {ListNode} l2
 * @return {ListNode}
 */
var mergeTwoLists = function(l1, l2) {
    var l = new ListNode();
    var temp = l;
    while(l1 && l2) {
        if (l1.val < l2.val) {
            temp.next = new ListNode(l1.val);
            l1 = l1.next;
            
        } else {
            temp.next = new ListNode(l2.val);
            l2 = l2.next;
        }
        temp = temp.next;
    }
    var finalL = l1 ? l1 : l2;
    
    temp.next = finalL;
    return l.next;
};

总结

方法不难,但是在怎么将指针指向新链表的下一个结点这个地方花了很长时间,说明对链表这种数据结构还不是很熟。

本文正在参与「掘金 2021 春招闯关活动」, 点击查看 活动详情