当前位置: 首页 > article >正文

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

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

开篇

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

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

题目描述在这里插入图片描述

代码思路

  通过创建一个新链表,然后遍历两个链表,每次取两个链表指向的值中小的那个,放入新链表中,直到两个遍历完成。
 当然,要优化一下,当有一个链表遍历完成时,我们可以直接让新链表的表尾指向另外一个链表未遍历的部分。

代码纯享版

/**
 * 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;
    }
}

代码逐行解析版

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,不是我们要返回的
    }
}

结语

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


http://www.kler.cn/a/146281.html

相关文章:

  • Redis 中 TTL 的基本知识与禁用缓存键的实现策略(Java)
  • NodeJS | 搭建本地/公网服务器 live-server 的使用与安装
  • 论文笔记-arXiv2025-A survey about Cold Start Recommendation
  • PyBroker:利用 Python 和机器学习助力算法交易
  • 【Go】Go Gorm 详解
  • Python GUI Pyside6 实例笔记
  • 3.golang数组以及切片
  • VMware系列:VMware16安装Win11虚拟机(最全步骤+踩坑)
  • 蓝桥杯第四场双周赛(1~6)
  • 搭建SRS视频服务器
  • 机器学习第13天:模型性能评估指标
  • qt pdf 模块简介
  • 15.解释Spring支持的几种bean的作用域
  • 禁用WordPress前台搜索功能
  • 人力资源管理后台 === 登陆+主页鉴权
  • 邮政快递查询单号查询入口,分析筛选出其中的提前签收件
  • 针对Arrays.asList的坑,可以有哪些处理措施
  • C#文件夹基本操作(判断文件夹是否存在、创建文件夹、移动文件夹、删除文件夹以及遍历文件夹中的文件)
  • laya2.13.3添加Button后报错
  • MySQL 批量插入记录报 Error 1390 (HY000)
  • Halcon 5分钟学会9点标定 带图片示例、示例源码
  • 【活动回顾】sCrypt在2023伦敦区块链大会上的精彩表现
  • Mysql使用周期性计划任务定时备份,发现备份的文件都是空的?为什么?如何解决?
  • 播放器开发(二):了解FFmpeg与SDL常用对象和函数
  • Redis面试题:redis做为缓存,数据的持久化是怎么做的?两种持久化方式有什么区别呢?这两种方式,哪种恢复的比较快呢?
  • 国产Ai大模型和chtgpt3.5的比较