龙空技术网

leetcode链表之合并两个排序的链表

码匠乱炖 109

前言:

此刻小伙伴们对“链表合并流程图”大致比较重视,朋友们都想要学习一些“链表合并流程图”的相关资讯。那么小编也在网摘上搜集了一些对于“链表合并流程图””的相关知识,希望咱们能喜欢,小伙伴们一起来学习一下吧!

本文主要记录一下leetcode链表之合并两个排序的链表

题目

输入两个递增排序的链表,合并这两个链表并使新链表中的节点仍然是递增排序的。示例1:​输入:1->2->4, 1->3->4输出:1->1->2->3->4->4​限制:​0 <= 链表长度 <= 1000​来源:力扣(LeetCode)链接:著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
题解
/** * 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指向尚未遍历完的链表的剩余节点

doche-bing-liang-ge-pai-xu-de-lian-biao-lcof

标签: #链表合并流程图