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

⭐算法OJ⭐链表排序【归并排序】(C++/JavaScript 实现)

文章目录

    • 148. Sort List
    • 解题思路
      • 归并排序的基本思想
      • 归并排序的步骤
    • 实现
      • 实现步骤
      • C++ 实现
      • JavaScript 实现
    • 复杂度
    • 总结

148. Sort List

Given the head of a linked list, return the list after sorting it in ascending order.

在这里插入图片描述

解题思路

链表排序问题可以通过多种方法解决,常见的方法是归并排序(Merge Sort)。归并排序(Merge Sort) 是一种基于 分治法(Divide and Conquer) 的排序算法。它的核心思想是将一个大问题分解为多个小问题,分别解决后再将结果合并。归并排序的主要特点是 稳定、时间复杂度低,并且适合处理 大规模数据。

归并排序的基本思想

  • 分(Divide)
    • 将待排序的数组或链表 递归地分成两半,直到每个子数组或子链表只包含一个元素(或为空)。
    • 单个元素的数组或链表本身就是有序的。
  • 治(Conquer)
    • 将两个 有序的子数组或子链表 合并成一个更大的有序数组或链表。
    • 合并过程中,通过比较两个子数组或子链表的元素,按顺序将较小的元素放入结果中。
  • 合(Combine)
    • 重复合并过程,直到所有子数组或子链表合并成一个完整的有序数组或链表。

归并排序的步骤

  • 分割:
    • 将数组或链表从中间分成两部分。
    • 对每一部分递归地进行分割,直到无法再分。
  • 合并:
    • 将两个有序的部分合并成一个有序的整体。
    • 合并时,通过比较两个部分的元素,按顺序将较小的元素放入结果中。
    • 给定一个链表的头节点 head,要求将其按升序排序,并返回排序后的链表。

实现

实现步骤

  • 分割链表:
    • 使用快慢指针法找到链表的中间节点。
    • 将链表从中间节点分为两部分。
  • 递归排序:对左右两部分链表分别递归调用 sortList 排序函数。
  • 合并链表:使用 merge 函数将两个有序链表合并为一个有序链表。
  • 虚拟头节点:在合并链表时,使用虚拟头节点简化代码。

C++ 实现

// 链表节点定义
struct ListNode {int val;ListNode* next;ListNode(int x) : val(x), next(nullptr) {}
};// 合并两个有序链表
ListNode* merge(ListNode* l1, ListNode* l2) {ListNode dummy(0); // 虚拟头节点ListNode* tail = &dummy;while (l1 && l2) {if (l1->val < l2->val) {tail->next = l1;l1 = l1->next;} else {tail->next = l2;l2 = l2->next;}tail = tail->next;}// 将剩余部分连接到尾部tail->next = l1 ? l1 : l2;return dummy.next;
}// 归并排序主函数
ListNode* sortList(ListNode* head) {if (!head || !head->next) {return head; // 链表为空或只有一个节点,直接返回}// 使用快慢指针找到链表的中间节点ListNode* slow = head;ListNode* fast = head->next;while (fast && fast->next) {slow = slow->next;fast = fast->next->next;}// 分割链表ListNode* mid = slow->next;slow->next = nullptr;// 递归排序左右两部分ListNode* left = sortList(head);ListNode* right = sortList(mid);// 合并两个有序链表return merge(left, right);
}

JavaScript 实现

// 链表节点定义
class ListNode {constructor(val, next = null) {this.val = val;this.next = next;}
}// 合并两个有序链表
function merge(l1, l2) {const dummy = new ListNode(0); // 虚拟头节点let tail = dummy;while (l1 && l2) {if (l1.val < l2.val) {tail.next = l1;l1 = l1.next;} else {tail.next = l2;l2 = l2.next;}tail = tail.next;}// 将剩余部分连接到尾部tail.next = l1 ? l1 : l2;return dummy.next;
}// 归并排序主函数
function sortList(head) {if (!head || !head.next) {return head; // 链表为空或只有一个节点,直接返回}// 使用快慢指针找到链表的中间节点let slow = head;let fast = head.next;while (fast && fast.next) {slow = slow.next;fast = fast.next.next;}// 分割链表const mid = slow.next;slow.next = null;// 递归排序左右两部分const left = sortList(head);const right = sortList(mid);// 合并两个有序链表return merge(left, right);
}

复杂度

  • 时间复杂度: O ( n l o g n ) O(n\, log\, n) O(nlogn)
  • 空间复杂度: O ( l o g n ) O(log\, n) O(logn)(递归栈空间)。

总结

通过归并排序,我们可以高效地对链表进行排序。这种方法不仅时间复杂度低,而且空间复杂度也较为优秀,适合处理大规模数据。掌握链表的分割和合并技巧对于解决类似的链表问题非常有帮助。

相关文章:

⭐算法OJ⭐链表排序【归并排序】(C++/JavaScript 实现)

文章目录 148. Sort List解题思路归并排序的基本思想归并排序的步骤 实现实现步骤C 实现JavaScript 实现 复杂度总结 148. Sort List Given the head of a linked list, return the list after sorting it in ascending order. 解题思路 链表排序问题可以通过多种方法解决&am…...

SegMAN模型详解及代码复现

SegMAN模型概述 模型背景 在深入探讨SegMAN模型之前&#xff0c;我们需要了解其研究背景。在SegMAN出现之前&#xff0c;计算机视觉领域的研究主要集中在以下几个方面&#xff1a; 手工制作方法&#xff0c;如SIFT基于卷积神经网络(CNN)的方法&#xff0c;如STN和PTN对平移、…...

Manus AI:多语言手写识别的技术革命与未来图景

摘要&#xff1a;在全球化浪潮下&#xff0c;跨语言沟通的需求日益迫切&#xff0c;但手写文字的多样性却成为技术突破的难点。Manus AI凭借其多语言手写识别技术&#xff0c;将潦草笔迹转化为精准数字文本&#xff0c;覆盖全球超百种语言。本文从技术原理、应用场景、行业价值…...

保姆级别使用Python实现“机器学习“案例

从安装到运行手把手教学,保证不迷路~ 🌈 零基础友好版教程 📦 第一步:安装必备工具包 别慌!这里有两种安装方式,选你顺手的 方式1:用代码自动安装(推荐新手) 直接在你的Python代码最前面加这几行,运行时会自动安装: # 把这坨代码贴在文件最前面! import sys im…...

K8s 1.27.1 实战系列(九)Volume

一、Volume介绍 Volume 指的是存储卷,包含可被Pod中容器访问的数据目录。容器中的文件在磁盘上是临时存放的,当容器崩溃时文件会丢失,同时无法在多个Pod中共享文件,通过使用存储卷可以解决这两个问题。 1、Volume 的核心作用 ​数据持久化与生命周期管理 Volume 的核心目标…...

Stable Diffusion游戏底模推荐

一、基础通用型底模 SDXLbase &#x1f4da; 官方原版底模&#xff0c;支持1024x1024高清出图&#xff0c;适用于各类游戏场景和角色的基础生成&#xff0c;建议作为微调训练的基准模型。 来源: 相关搜索结果 写实风格搭配推荐 &#x1f3a8; 搭配 9realisticSDXL 或 麻袋real…...

GNU Binutils 全工具指南:从编译到逆向的完整生态

1. GNU Binutils 全工具指南&#xff1a;从编译到逆向的完整生态 1. GNU Binutils 全工具指南&#xff1a;从编译到逆向的完整生态 1.1. 引言1.2. 工具分类速查表1.3. 核心工具详解 1.3.1. 编译与汇编工具 1.3.1.1. as&#xff08;汇编器&#xff09;1.3.1.2. gcc&#xff08;…...

nginx 打造高性能 API 网关(‌Building a High-Performance API Gateway with Nginx)

Nginx 打造高性能 API 网关 引言&#xff1a; 在现代微服务架构中&#xff0c;API 网关扮演着至关重要的角色。它不仅负责统一路由请求&#xff0c;还承担着身份验证、负载均衡、流量控制、日志记录等多重任务。而在众多的 API 网关实现方案中&#xff0c;Nginx 作为一个高性能…...

理解字符流和字节流,节点流和处理流、缓冲流、InputStreamReader、BufferInputStream、BufferReader...

DAY10.2 Java核心基础 IO流 字符流和字节流 字符流和字节流在每次处理数据的单位不同&#xff0c;一个是字符&#xff0c;一个是字节 如果复制文件类型是文本类型&#xff0c;字节流字符流都可以 如果复制的文件类型是非文本类型&#xff0c;则只能使用字节流&#xff0c;使…...

Securing a Linux server

Is your Linux server safe from hackers? Can they get hacked? Freak out about getting your server compromised and getting your data leaked? Take a look at some of the tips you can take to secure and protect your Linux server. 1. SSH security SSH is l…...

DBeaver安装教程+连接TDengine数据库

为TDengine安装的DBeaver教程 安装 23.1.1 版本以上的DBeaver 因为官方文档说这个版本之上的DBeaver才支持TDengine内嵌前往DBeaver 官方文档进行版本下载滑到链接最下面点击进入 点击download&#xff0c;进入选择下载版本 等待下载成功即可双击自行安装 打开数据库连接TDen…...

postgreSQL window function高级用法

正常使用&#xff1a;相当于对每个row做一次子查询 SELECT depname, empno, salary, avg(salary) OVER (PARTITION BY depname) FROM empsalary;order by 区别window frame and partition 没有order by&#xff0c; window function是对整个partition起作用&#xff0c; part…...

【三维重建】Proc-GS:使用3DGS的程序性城市建筑生成

标题&#xff1a;《Proc-GS: Procedural Building Generation for City Assembly with 3D Gaussians》 项目&#xff1a;https://city-super.github.io/procgs/ 来源&#xff1a;香港中文大学&#xff1b;上海人工智能实验室 等 文章目录 摘要一、 程序代码定义 (Procedural Co…...

商业智能BI的未来,如何看待AI+BI这种模式?

昨天在和一位朋友线上聊天的时候&#xff0c;提了一个问题&#xff0c;你是如何看待AI&#xff08;人工智能&#xff09;BI&#xff08;商业智能&#xff09;这种模式和方向的&#xff0c;我大概来说一下我个人的看法。 以我在商业智能BI项目中接触到的行业和企业&#xff0c;…...

【计算机视觉】手势识别

手势识别是计算机视觉领域中的重要方向&#xff0c;通过对摄像机采集的手部相关的图像序列进行分析处理&#xff0c;进而识别其中的手势&#xff0c;手势被识别后用户就可以通过手势来控制设备或者与设备交互。完整的手势识别一般有手的检测和姿态估计、手部跟踪和手势识别等。…...

装饰器模式的C++实现示例

核心思想 装饰器设计模式是一种结构型设计模式&#xff0c;它允许动态地为对象添加额外的行为或职责&#xff0c;而无需修改其原始类。装饰器模式通过创建一个装饰器类来包装原始对象&#xff0c;并在保持原始对象接口一致性的前提下&#xff0c;扩展其功能。 装饰器模式的核…...

Python+DeepSeek:开启AI编程新次元——从自动化到智能创造的实战指南

文章核心价值 技术热点:结合全球最流行的编程语言与国产顶尖AI模型实用场景:覆盖代码开发/数据分析/办公自动化等高频需求流量密码:揭秘大模型在编程中的创造性应用目录结构 环境搭建:5分钟快速接入DeepSeek场景一:AI辅助代码开发(智能补全+调试)场景二:数据分析超级助…...

25.3.12.Linux内核如何和设备树协同工作的?

1.编写设备树 cd arch/riscv/boot/dts/ 再cd到厂商,例如下述内容。 2.编译设备树(dts->dtb)通过dtc命令来转换 3.解析设备树 例如上述内容,都是对设备树的解析。 这里重点说一下内核对设备树的处理吧,因为这个内容是设备树的重点了。 从源代码文件 dts 文件开始...

python中路径操作简介

一、./的基础含义 ​当前目录 ./表示当前工作目录&#xff08;Current Working Directory, CWD&#xff09;&#xff0c;即Python脚本运行时所在的目录。例如&#xff1a; open(./data.txt, r) # 打开当前目录下的data.txt文件 ​作用&#xff1a;避免直接写文件名可能引发的路…...

Flutter 基础组件 Text 详解

目录 1. 引言 2. 基本使用 3. 自定义样式 4. 文本对齐与溢出控制 5. 外边距 5.1 使用 Container 包裹 5.2 使用 Padding 组件 5.3 在 Row/Column 中使用 5.4 动态边距调整 5.5 关键区别说明 5.6 设置 margin 无效 6. 结论 相关推荐 1. 引言 Text 组件是 Flutter 中…...

Torch 模型 model => .onnx => .trt 及利用 TensorTR 在 C++ 下的模型部署教程

一、模型训练环境搭建和模型训练 模型训练环境搭建主要牵扯 Nvidia driver、Cuda、Cudnn、Anaconda、Torch 的安装&#xff0c;相关安装教程可以参考【StarCoder 微调《个人编程助手: 训练你自己的编码助手》】中 5.1 之前的章节。 模型训练的相关知识可以参考 Torch的编程方…...

FreeSWITCH 之 chat

要把 FreeSWITCH 之 chat 完全研究清楚&#xff0c;似乎不容易 发送&#xff0c;路由&#xff0c;接收 跟哪些模块有关 等等 咱一边查资料&#xff0c;一边整理&#xff0c;不着急 先看看 Kamalio 怎么发 MESSAGE loadmodule "uac.so"route[uac_send_message] {…...

如何在Spring Boot中配置和使用MyBatis-Plus

在当今的Java开发中&#xff0c;Spring Boot已经成为了一个非常流行的框架&#xff0c;而MyBatis-Plus则是一个强大的ORM框架&#xff0c;为开发人员提供了更简便的数据库操作方式。很多开发者都在使用Spring Boot和MyBatis-Plus的组合来快速构建高效的应用。今天就来聊聊如何在…...

爱普生可编程晶振SG-8200CJ特性与应用

在高速发展的电子技术领域&#xff0c;时钟源作为电子系统的“心脏”&#xff0c;其性能直接影响设备的稳定性与可靠性。爱普生SG-8200CJ可编程晶振凭借其优秀的频率精度、低抖动性能及广泛的环境适应性&#xff0c;正成为众多领域的得力之选&#xff0c;为各类设备的高效运行与…...

ubuntu中用docker下载opengauss

1.安装docker sudo apt install docker.io2.拉取opengauss镜像 sudo docker pull enmotech/opengauss3.创建容器 sudo docker run --name opengauss --privilegedtrue -d -e GS_PASSWORDEnmo123 enmotech/opengauss:latest3.5.如果容器停止运行&#xff08;比如关机了&#…...

tslib

使用tslib来读取触摸屏的数据&#xff0c;可以得到原始数据&#xff0c;也可以在原始数据的基础上进行一些处理。比如有些触摸屏比较不稳定&#xff0c;跳动比较大&#xff0c;我们可以将跳动比较大的数据给删除掉 plugins里面的每个文件都会被编译成一个动态库&#xff0c;这些…...

MANUS怎么用

&#xff08;1&#xff09;分析方法论我过去说过一个分析模型&#xff1a;供给侧-消费侧。供给侧想做大&#xff0c;得靠生态集成。消费侧想坐大&#xff0c;得靠交互体验。&#xff08;2&#xff09;交互体验我先给大家讲一下计算机产业发展70来年&#xff0c;在交互上的变化。…...

Spring Cloud Alibaba 实战:Sentinel 保障微服务的高可用性与流量防护

1.1 Sentinel 作用 Sentinel 是阿里巴巴开源的一款 流量控制和熔断降级 框架&#xff0c;主要用于&#xff1a; 流量控制&#xff1a;限制 QPS&#xff0c;防止流量暴增导致系统崩溃熔断降级&#xff1a;当某个服务不可用时自动降级&#xff0c;避免故障扩散热点参数限流&…...

大数据技术在土地利用规划中的应用分析

大数据技术在土地利用规划中的应用分析 一、引言 土地利用规划是对一定区域内的土地开发、利用、整治和保护所作出的统筹安排与战略部署,对于实现土地资源的优化配置、保障社会经济的可持续发展具有关键意义。在当今数字化时代,大数据技术凭借其海量数据处理、高效信息挖掘等…...

MoonSharp 文档三

MoonSharp 文档一-CSDN博客 MoonSharp 文档二-CSDN博客 MoonSharp 文档四-CSDN博客 MoonSharp 文档五-CSDN博客 7.Proxy objects&#xff08;代理对象&#xff09; 如何封装你的实现&#xff0c;同时又为脚本提供一个有意义的对象模型 官方文档&#xff1a;MoonSharp 在实际…...