题目描述

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

示例1:

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

0 <= 链表长度 <= 1000

注意:本题与主站 21 题相同:https://leetcode-cn.com/problems/merge-two-sorted-lists/

通过次数61,236提交次数83,165

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/he-bing-liang-ge-pai-xu-de-lian-biao-lcof
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

题解

  1. /**
  2. * Definition for singly-linked list.
  3. * function ListNode(val) {
  4. * this.val = val;
  5. * this.next = null;
  6. * }
  7. */
  8. /**
  9. * @param {ListNode} l1
  10. * @param {ListNode} l2
  11. * @return {ListNode}
  12. */
  13. var mergeTwoLists = function(l1, l2) {
  14. if (l1 === null) return l2;
  15. if (l2 === null) return l1;
  16. let root = null;
  17. if (l1.val < l2.val) {
  18. root = new ListNode(l1.val);
  19. l1 = l1.next;
  20. } else {
  21. root = new ListNode(l2.val);
  22. l2 = l2.next;
  23. }
  24. let now = root;
  25. while (l1 || l2) {
  26. if (l1 === null) {
  27. now.next = l2;
  28. break;
  29. }
  30. if (l2 === null) {
  31. now.next = l1;
  32. break;
  33. }
  34. if (now.val === l1.val || l1.val <= l2.val) {
  35. now.next = new ListNode(l1.val);
  36. now = now.next;
  37. l1 = l1.next;
  38. } else if (now.val === l2.val || l2.val <= l1.val) {
  39. now.next = new ListNode(l2.val);
  40. now = now.next;
  41. l2 = l2.next;
  42. }
  43. }
  44. return root;
  45. };