【算法萌新闯力扣】:合并两个有序链表

力扣题目:合并两个有序链表

开篇

今天是备战蓝桥杯的第24天及算法村开营第2天。根据算法村的讲义,来刷链表的相关题目。今天要分享的是合并两个有序链表。

题目链接: 21.合并两个有序链表

题目描述

代码思路

通过创建一个新链表,然后遍历两个链表,每次取两个链表指向的值中小的那个,放入新链表中,直到两个遍历完成。

当然,要优化一下,当有一个链表遍历完成时,我们可以直接让新链表的表尾指向另外一个链表未遍历的部分。

代码纯享版

java 复制代码
/**
 * Definition for singly-linked list.
 * public class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode() {}
 *     ListNode(int val) { this.val = val; }
 *     ListNode(int val, ListNode next) { this.val = val; this.next = next; }
 * }
 */
class Solution {
    public ListNode mergeTwoLists(ListNode list1, ListNode list2) {
        ListNode head = new ListNode(-1);
        ListNode node = head;
        while(list1 != null && list2 != null){
            if(list1.val > list2.val) {
            node.next = list2;
            list2 = list2.next;
            }
             else{
                node.next = list1;
                list1 = list1.next;
            }
            node = node.next;
        }
        if(list1 == null) node.next = list2;
        else node.next = list1;
        return head.next;
    }
}

代码逐行解析版

java 复制代码
class Solution {
    public ListNode mergeTwoLists(ListNode list1, ListNode list2) {
        ListNode head = new ListNode(-1); //创建一个头结点,赋值为-1,值是随便赋的。头结点主要是为了方便最后返回链表
        ListNode node = head; //创建结点node指向head,之后的操作都由node指向,head就一直处在链表的头
        while(list1 != null && list2 != null){ //循环条件是两个链表都不为空时
            if(list1.val > list2.val) {//如果表1的值大于表2
            node.next = list2; //把表2的值赋给node.next,注意不是node,赋给node的话,head就没意义了
            list2 = list2.next; //list2指向下一个结点
            }
             else{ //与上面同理,把list2换成list1
                node.next = list1; 
                list1 = list1.next;
            }
            node = node.next; //node指向下一个结点
        }
        if(list1 == null) node.next = list2;//循环结束证明还有至多一个表不为空,让node.next指向不为空的表
        else node.next = list1;
        return head.next; //返回head.next,注意:head是-1,不是我们要返回的
    }
}

结语

如果这道力扣题的分享对您有所帮助,点个关注,我会每天更新力扣题目的讲解,与大伙儿一同向前迈进!

相关推荐
才疏学浅7433 分钟前
批量下载鹏程实验室数据的方法
java·开发语言·word
bubiyoushang8885 分钟前
基于 TGLVM 算法的迁移学习分类系统
算法·分类·迁移学习
皮卡祺q10 分钟前
【JVM】:类加载机制,jvm内存布局,垃圾回收,String 不可变性源码分析
java·开发语言·jvm·多线程·string
JAVA面经实录91712 分钟前
Java核心底层原理全集(终版无遗漏·生产级PDF)
java·开发语言·学习
java修仙传13 分钟前
实习日志:完成算法调用总接口并修复联调问题
java·开发语言·数据库
铅笔小新z14 分钟前
【Linux】进程间通信(IPC)
java·linux·运维
Rabitebla14 分钟前
深入理解 C++ STL:stack 和 queue 的底层原理与实现
c语言·开发语言·数据结构·c++·算法
极客先躯16 分钟前
高级java每日一道面试题-2025年12月11日-实战篇[Docker]-如何配置 Docker 的资源限制(CPU、内存、磁盘)?
java·docker·如何配置docker的资源限制·资源限制的底层支柱·linux cgroups·cpu 限制·从逻辑到策略
通信仿真爱好者23 分钟前
【无标题】
人工智能·算法·机器学习
總鑽風26 分钟前
单点登录sso 微服务加网关gateway
java·微服务·gateway·jwt·单点登录