序
本文次要记录一下 leetcode 链表之合并两个排序的链表
题目
输出两个递增排序的链表,合并这两个链表并使新链表中的节点依然是递增排序的。示例 1:输出:1->2->4, 1->3->4
输入:1->1->2->3->4->4
限度:0 <= 链表长度 <= 1000
起源:力扣(LeetCode)链接:https://leetcode-cn.com/problems/he-bing-liang-ge-pai-xu-de-lian-biao-lcof
著作权归领扣网络所有。商业转载请分割官网受权,非商业转载请注明出处。
题解
/**
* Definition for singly-linked list.
* public class ListNode {
* int val;
* ListNode next;
* ListNode(int x) {val = x;}
* }
*/
class Solution {public ListNode mergeTwoLists(ListNode l1, ListNode l2) {ListNode newHead = new ListNode(-1);
ListNode cursor = newHead;
while(l1 != null && l2 != null) {if (l1.val <= l2.val) {
cursor.next = l1;
l1 = l1.next;
} else {
cursor.next = l2;
l2 = l2.next;
}
cursor = cursor.next;
}
if (l1 == null) {cursor.next = l2;}
if (l2 == null) {cursor.next = l1;}
return newHead.next;
}
}
- 这里先创立一个 newHead 节点来示意合并后链表的头指针,而后创立一个 cursor,其初始值为 newHead;之后同时遍历 l1 及 l2,取最小的作为 cursor.next,同时该链表后退一个节点,并且 cursor 跟着后退;最初再将 cursor.next 指向尚未遍历完的链表的残余节点;之后返回头指针指向的节点
小结
合并两个有序链表的基本思路就是设置一个 cursor 以及新链表的头指针,而后同时遍历两个链表,取小的节点作为 cursor 的 next,而后该链表往后退,cursor 也跟着往后退,最初再将 cursor.next 指向尚未遍历完的链表的残余节点
doc
- he-bing-liang-ge-pai-xu-de-lian-biao-lcof