Leecode 21 合并两个有序链表

简介: 设置一个第三结点preHead,借助三个工具指针pre, l1, l2,分别代表三个指针,初始分别指向三个结点

题目

image.png

image.png

思路:


设置一个第三结点preHead,借助三个工具指针pre, l1, l2,分别代表三个指针,初始分别指向三个结点

比较 l1、l2值的大小,不断建立连接。直至连接到其中一条链表的末尾,退出

判断第2步后还有哪个结点没有连接,连接最后一个结点

返回preHead.next,即新链表的头结点(不包括preHead).

image.png


class Solution {
    public ListNode mergeTwoLists(ListNode list1, ListNode list2) {
        ListNode preHead=new ListNode(-1);
        ListNode pre=preHead;
        ListNode l1=list1;
        ListNode l2=list2;
        while(l1!=null && l2!=null){
            if(l1.val<=l2.val){
                pre.next=l1;
                l1=l1.next;
            }else{
                pre.next=l2;
                l2=l2.next;
            }
            pre=pre.next;
        }
        if(l1==null){
            pre.next=l2;
        }else{
            pre.next=l1;
        }
        return preHead.next;
    }
}


相关文章
|
5天前
|
算法
LeetCode刷题---21.合并两个有序链表(双指针)
LeetCode刷题---21.合并两个有序链表(双指针)
|
5天前
|
存储 算法
头歌:第1关:有序单链表的插入操作
头歌:第1关:有序单链表的插入操作
136 0
|
5天前
【力扣】21. 合并两个有序链表
【力扣】21. 合并两个有序链表
|
5天前
|
C语言
反转链表、链表的中间结点、合并两个有序链表【LeetCode刷题日志】
反转链表、链表的中间结点、合并两个有序链表【LeetCode刷题日志】
|
5天前
Leecode之反转链表
Leecode之反转链表
|
5天前
Leecode之合并两个有序链表
Leecode之合并两个有序链表
|
5天前
Leecode之分割链表
Leecode之分割链表
|
5天前
Leecode之环形链表进阶
Leecode之环形链表进阶
|
5天前
Leecode之相交链表
Leecode之相交链表
|
5天前
Leecode之环形链表
Leecode之环形链表