leetcode 热题 100_合并两个有序链表

news/2024/7/24 9:29:39 标签: leetcode, 算法

题解一:

        迭代:分别用两个指针遍历两段链表,逐步比较两链表的节点,将值较大的节点存入新链表,同时指针移动,直到某段链表遍历结束,将另一段链表剩余的节点存入新链表。需要注意存入新链表时要用新链表.next来存避免新链表指针出错。

import java.awt.*;

class Solution {
    public ListNode mergeTwoLists(ListNode list1, ListNode list2) {
        if (list1 == null) return list2;
        else if (list2 == null) return list1;

        ListNode result = new ListNode();
        ListNode temp = result;
        ListNode p1 = list1, p2 = list2;
        while (p1 != null && p2 != null) {
            if (p1.val <= p2.val) {
                temp.next = p1;
                p1 = p1.next;
            } else {
                temp.next = p2;
                p2 = p2.next;
            }
            temp = temp.next;
        }

        if (p1 == null && p2 != null) {
            while (p2 != null) {
                temp.next = p2;
                p2 = p2.next;
                temp = temp.next;
            }
        } else if (p1 != null && p2 == null) {
            while (p1 != null) {
                temp.next = p1;
                p1 = p1.next;
                temp = temp.next;
            }
        }

        return result.next;
    }
}

题解二:

        递归:将迭代的过程通过递归来实现,但由于递归核心代码是从链表末端开始执行的,所以无需考虑链表节点的覆盖问题,不容易出错,但递归也较难理解。具体递归步骤是先确定结束条件,判断两段链表是否为null再比较传入的两节点值(记做节点ab),将较大值节点a指向下一节点,这里下一节点可能是和它比较的节点b,或者它原先的下一节点a.next,具体要进行下一步比较,所以我们将节点ba.next作为参数递归调用,并将较大的节点作为返回值。附上图解(来源. - 力扣(LeetCode))

import java.awt.*;

class Solution {
    public ListNode F(ListNode list1, ListNode list2) {
        if (list1 == null) return list2;//递归结束条件
        else if (list2 == null) return list1;

        if (list1.val <= list2.val) {//调用递归并返回
            list1.next = F(list1.next, list2);
            return list1;
        } else {
            list2.next = F(list1, list2.next);
            return list2;
        }
    }

    public ListNode mergeTwoLists(ListNode list1, ListNode list2) {
        ListNode result = F(list1, list2);
        return result;
    }
}


http://www.niftyadmin.cn/n/5424824.html

相关文章

【硬件基础】电容的选型

1、电容的理论基础 电容器的本质就是储能&#xff0c;充放电 根据作用可分为&#xff1a;滤波电容&#xff0c;旁路电容&#xff0c;耦合电容&#xff0c;退耦电容&#xff0c;自举电容 2、电容的取值 计算取值&#xff0c;查手册&#xff0c;经验取值 3、电容的选取 分为铝…

探索TikTok云手机在社交媒体营销的作用

近年来&#xff0c;TikTok作为全球短视频平台之一&#xff0c;其用户基数呈现持续增长的趋势。伴随社交媒体的蓬勃发展&#xff0c;企业和个人纷纷涌入TikTok平台&#xff0c;追求更广泛的曝光和用户互动。为满足这一需求&#xff0c;TikTok云手机应运而生。本文将深度剖析TikT…

docker部署rustdesk远程控制服务器

文章目录 前言一、rustdesk是什么&#xff1f;二、服务端配置1.安装docker2、拉取镜像3、运行容器3、防火墙配置 三、客户端配置 前言 本实例主要方便在内网没有远程控制环境下使用 一、rustdesk是什么&#xff1f; rustdesk是github上一个开源的远程控制项目。 二、服务端…

十二、软考-系统架构设计师笔记-信息系统架构设计理论与实践

1、信息系统架构基本概念及发展 信息系统架构的定义 信息系统架构是该系统的一个(或多个)结构&#xff0c;而结构由软件元素、元素的外部可见属性及它们之间的关系组成。 信息系统架构分类 信息系统架构分为物理结构与逻辑结构两种&#xff1a; 物理结构是指不考虑系统各部分…

【JS逆向学习】猿人学第六题 js混淆 回溯

逆向目标 网址&#xff1a;https://match.yuanrenxue.cn/match/6接口&#xff1a;https://match.yuanrenxue.cn/api/match/6参数&#xff1a;payload(m、q) 逆向过程 老规矩&#xff0c;先来分析网络请求&#xff0c;加密的地方一目了然&#xff0c;没什么可多说的&#xff…

Django 学习笔记(Day1)

「写在前面」 本文为千锋教育 Django 教程的学习笔记。本着自己学习、分享他人的态度&#xff0c;分享学习笔记&#xff0c;希望能对大家有所帮助。 目录 0 课程介绍 1 Django 快速入门 1.1 Django 介绍 1.2 Django 安装 1.3 创建 Django 项目 1.4 运行 Django 项目 1.5 数据迁…

C++ std::list的merge()使用与分析

看到《C标准库第2版》对list::merge()的相关介绍&#xff0c;令我有点迷糊&#xff0c;特意敲代码验了一下不同情况的调用结果。 《C标准库第2版》对list::merge()的相关介绍 list::merge()定义 merge()的作用就是将两个list合并在一起&#xff0c;函数有2个版本&#xff1a;…

《Ubuntu20.04环境下的ROS进阶学习2》

一、使用rviz和gazebo实时仿真 本节我们将使用三维可视化工具rviz&#xff08;The Robot Visualization Tool&#xff09;来实时观测gazebo仿真中的激光雷达数据。 二、打开仿真gazebo项目 如果您已经按照 《Ubuntu20.04环境下的ROS进阶学习0》-CSDN博客 如果您已经按照上次的文…