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

排序链表--字节跳动

少年的书桌上没有虚度的光阴

题目描述

请你对链表进行排序

思路分析

  • 核心思想:归并排序

有三个部分

链表排序实现

1. merge 函数

21.见 合并两个有序链表,

  • 首先创建一个虚拟头节点 newhead,并使用指针 tail 来构建合并后的链表。

  • 通过循环比较 list1list2 节点的值,将较小值的节点连接到 tail 后面,并相应地移动指针。

  • 当其中一个链表遍历完后,将另一个链表的剩余部分直接连接到 tail 后面。

  • 最后返回虚拟头节点的下一个节点,即合并后链表的头节点。

2. findMiddle 函数

该函数用于寻找链表的中间节点,采用快慢指针的方法:

  • fast 指针每次移动两步,slow 指针每次移动一步。

  • fast 指针到达链表末尾时,slow 指针就指向链表的中间节点。

3. sortList 函数

这是核心的排序函数,使用归并排序算法对链表进行排序:

  • 首先判断链表是否为空或只有一个节点,如果是则直接返回该链表。

  • 调用 findMiddle 函数找到链表的中间节点,将链表分成左右两部分。

  • 递归地对左右两部分链表分别调用 sortList 函数进行排序。

  • 最后调用 merge 函数将两个有序的子链表合并成一个有序链表。

完整代码

class Solution {
public:// 合并两个有序链表ListNode* merge(ListNode* list1, ListNode* list2) {auto  newhead = new ListNode(0); // 使用明确的类型名称auto  tail = newhead;while (list1 && list2) {if (list1->val < list2->val) {tail->next = list1;list1 = list1->next;} else {tail->next = list2;list2 = list2->next;}tail = tail->next;}tail->next = list1 ? list1 : list2; // 处理剩余部分return newhead->next;}// 寻找中间节点ListNode* findMiddle(ListNode* head) {ListNode* fast = head;ListNode* slow = head;while (fast->next && fast->next->next) {fast = fast->next->next;slow = slow->next;}return slow;}// 归并排序链表ListNode* sortList(ListNode* head) {if (head==NULL ||head->next==NULL) return head; // 检查链表长度// 找到链表的中间节点ListNode* mid = findMiddle(head);ListNode* right = mid->next;mid->next = nullptr; // 切分链表// 递归地对左右两部分进行排序ListNode* l = sortList(head);ListNode* r = sortList(right);// 合并两个有序链表return merge(l, r);}
}
};

复杂度分析

  • 时间复杂度: O(nlogn)

  • 空间复杂度: O(logn)

相关文章:

排序链表--字节跳动

少年的书桌上没有虚度的光阴 题目描述 请你对链表进行排序 思路分析 核心思想&#xff1a;归并排序 有三个部分 链表排序实现 1. merge 函数 21.见 合并两个有序链表&#xff0c; 首先创建一个虚拟头节点 newhead&#xff0c;并使用指针 tail 来构建合并后的链表。 通过…...

Python爬虫-批量爬取股票数据猫各股票代码

前言 本文是该专栏的第47篇,后面会持续分享python爬虫干货知识,记得关注。 本文笔者以股票数据猫为例子,基于Python爬虫,批量获取各股票代码数据。 具体实现思路和详细逻辑,笔者将在正文结合完整代码进行详细介绍。废话不多说,下面跟着笔者直接往下看正文详细内容。(附…...

打开Firefox自动打开hao360.hjttif.com标签解决方案

现象 打开Firefox自动打开hao360.hjttif.com标签&#xff0c;同时用户自己设置的主页也会在一个新标签打开。点击hjttif这个标签&#xff0c;就会跳转到hao.360.com 打开Edge不会出现上述现象。搜遍全网都找不到解决方法。博客园上有一篇文章2025-02-14.防流氓软件篡改主页提到…...

【爬虫基础】第一部分 网络通讯-编程 P3/3

上节内容回顾&#xff1a;【爬虫基础】第一部分 网络通讯 P1/3-CSDN博客 【爬虫基础】第一部分 网络通讯-Socket套接字 P2/3-CSDN博客 相关文档&#xff0c;希望互相学习&#xff0c;共同进步 风123456789&#xff5e;-CSDN博客 前言 1.知识点碎片化&#xff1a;每个网站实现…...

Ubuntu 下 nginx-1.24.0 源码分析 - ngx_atoi 函数

ngx_atoi 声明在 src/core/ngx_string.h ngx_int_t ngx_atoi(u_char *line, size_t n); 定义在 src/core/ngx_string.c ngx_int_t ngx_atoi(u_char *line, size_t n) {ngx_int_t value, cutoff, cutlim;if (n 0) {return NGX_ERROR;}cutoff NGX_MAX_INT_T_VALUE / 10;cutlim…...

PG:ERROR: cannot freeze committed xmax

目录 原因**问题原因****PostgreSQL 底层逻辑** 解决方案1**问题分析****排查步骤****1. 检查长时间运行的事务****2. 检查未提交的事务****3. 检查 autovacuum 配置****4. 检查事务 ID 使用情况****5. 检查表的 relfrozenxid** **解决方法****1. 手动运行 VACUUM FREEZE****2.…...

《论软件的可靠性评价》审题技巧 - 系统架构设计师

论软件的可靠性评价写作框架 一、考点概述 软件可靠性评价作为软件可靠性活动的关键环节&#xff0c;是确保软件质量、提升用户体验的重要手段。本题主要考察以下几个方面的内容&#xff1a; 首先&#xff0c;本题要求考生理解并掌握软件可靠性评价的基本概念及其在软件开发…...

【项目设计】自主HTTP服务器

目录 项目介绍 网络协议栈介绍 协议分层 数据的封装与分用 HTTP相关知识介绍 HTTP的特点 URL格式 URI、URL、URN HTTP的协议格式 HTTP响应协议格式 HTTP的请求方法 HTTP的状态码 HTTP常见的Header CGI机制介绍 CGI机制的概念 CGI机制的实现步骤 CGI机制的意义 …...

Linux操作系统:基于Linux的个人Web服务器搭建与自动化运维实践

基于Linux的个人Web服务器搭建与自动化运维实践 摘要 在互联网的海洋中&#xff0c;每个人都想拥有一艘属于自己的小船——一个个人Web服务器。Linux作为开源界的“老大哥”&#xff0c;无疑是搭建Web服务器的最佳选择。本文通过幽默风趣的方式&#xff0c;详细介绍了在Linux…...

[创业之路-321]:创新开拓思维和经营管理思维的比较

目录 一、概述 1.1、定义与内涵 1、创新开拓思维&#xff1a; 2、经营管理思维&#xff1a; 1.2、特点与优势 1、创新开拓思维的特点与优势&#xff1a; 2、经营管理思维的特点与优势&#xff1a; 3、应用场景与限制 4、总结 二、创新开拓思维与经营管理思维&#xf…...

vivado修改下载器下载速率

Error Launching Program X Error while launching program: fpga configuration failed. DONE PIN is not HIGH 原因是下载器速度太快了。先从任务管理器中关闭hw_server.exe试一下,要是不行就按下面三种方法解决。 第一种方法可以不用修改下载速度,直接先从vivado中将bit流…...

运维基线方案说明

1. 总体思路 建立运维基线的核心目标是保障系统稳定性、提升安全性、及时响应异常事件并不断优化系统性能。初创公司资源有限&#xff0c;方案应尽可能简单、易用&#xff0c;同时具备一定的自动化和标准化能力。建议从以下几个层面入手&#xff1a; 标准化文档&#xff1a;制…...

pycharm中配置PyQt6详细教程

PyQt6 是 Qt 框架的 Python 绑定库,基于 Qt 6 开发,专为创建跨平台图形用户界面(GUI)应用程序设计。 本章教程,主要记录在pycharm中配置使用PyQt6的流程。 一、安装基础环境 在此之前,你需要提前安装好Python解释器,推荐使用anaconda创建虚拟环境。 conda create -n pyt…...

大湾区经济网报道:2025春运收官 全国跨区流动90亿,大湾区12亿人次

&#xff08;原标题&#xff1a;2025年春运收官&#xff1a;全国跨区流动超90亿人次 大湾区贡献12亿人次&#xff09; 大湾区经济网2月23日电&#xff08;记者 余芳&#xff09;2025年春运昨日&#xff08;2月22日&#xff09;正式结束&#xff0c;全国跨区域人员流动量达90.2…...

Docker用户的困境:免费项目的减少与成本的增加

摘要 在生产环境中&#xff0c;Docker用户正面临新的挑战&#xff1a;免费项目逐渐减少&#xff0c;收费服务成为主流趋势。表面上免费的选项&#xff0c;由于缺乏必要的支持和及时更新&#xff0c;反而可能导致更高的隐性成本。对于依赖Docker进行开发和部署的企业而言&#x…...

1.4 嵌入式系统的软件

嵌入式系统的开发流程中&#xff0c;硬件和固件设计完成后&#xff0c;嵌入式软件承担起实现功能、用户交互、系统集成和性能优化等任务&#xff1b;嵌入式系统软件分为设备驱动、操作系统和应用程序三个层面。 因此嵌入式系统软件开发工程师通常分为三类&#xff1a;嵌入式系统…...

PHP2(WEB)

##解题思路 打开页面什么线索都没有&#xff0c;目录扫描只是扫出来一个index.php&#xff0c;而源代码没有东西&#xff0c;且/robots.txt是不允许访问的 于是一番查询后发现&#xff0c;有个index.phps的文件路径&#xff0c;里头写着一段php的逻辑&#xff0c;对url的id参数…...

【精调】LLaMA-Factory 快速开始1: Meta-Llama-3.1-8B-Instruct

llamafactory-cli train examples/train_lora/llama3_lora_sft.yaml llamafactory-cli chat examples/inference/llama3_lora_sft.yaml llamafactory-cli export examples/merge_lora/llama3_lora_sft.yaml模型下载 git clone https://www.modelscope.cn/LLM-Research/Meta-Lla…...

一、计算机等级考试——题库

&#xff08;1&#xff09;选择题 &#xff08;2&#xff09;基本操作题 &#xff08;3&#xff09;上网题 &#xff08;4&#xff09;文字题 &#xff08;5&#xff09;表格题 &#xff08;6&#xff09;演示文稿 二、计算机等级考试——标准评分 &#xff08;1&#xff09;选…...

Android系统开发 给system/app传包报错

一、现象 adb 命令推送apk到system/app下提示 remote couldnt create file: Read-only file system demo /oem/appsystem app 在Android设备上&#xff0c;/system 分区通常是只读的&#xff08;Read-only file system&#xff09;&#xff0c;这意味着普通用户或应用程序…...

从零搭建DMR数字通联网络:手台、MMDVM热点与Brandmeister实战指南

1. 从零开始&#xff1a;DMR数字通联基础认知 第一次接触DMR数字通联的朋友&#xff0c;可能会被一堆专业术语搞得晕头转向。简单来说&#xff0c;DMR&#xff08;Digital Mobile Radio&#xff09;就像是用手机打电话&#xff0c;只不过我们用的是无线电手台。想象一下&#x…...

GPT image-2 怎么调用?2026 完整接入教程 + 踩坑实录

上周接了个小活&#xff0c;甲方要做批量生成商品主图的工具。需求很明确&#xff1a;传一段文字描述&#xff0c;出一张高质量商品图。我第一反应是 DALLE 3&#xff0c;但试了几张发现文字渲染还是拉胯&#xff0c;英文勉强能看&#xff0c;中文直接乱码。然后想起 OpenAI 前…...

超导体-硅约瑟夫森结技术解析与应用

1. 超导体-硅约瑟夫森结技术解析约瑟夫森结作为连接经典与量子世界的桥梁&#xff0c;其核心在于两个超导体之间形成的弱耦合结构。当我在实验室第一次观察到4.2K温度下NbN/a-Si/NbN结的I-V特性曲线时&#xff0c;那个清晰的能隙电压跳变让我至今难忘。这种超导体-硅-超导体(SC…...

skeyevss-performance 长任务Panic隔离与协程恢复源码设计

试用安装包下载 | SMS | 在线演示 开源项目地址&#xff1a;https://github.com/openskeye/go-vss 背景 VSS 长期运行&#xff0c;任何 nil 指针、越界、第三方库 bug 都可能触发 panic。若 panic 发生在 唯一 的 SIP 发送循环或 Catalog 定时器里&#xff0c;会导致 整类信…...

别再乱删了!深入理解Adobe正版服务(AGSService)运行机制与安全移除指南

深入解析Adobe正版服务运行机制与安全处置方案 当你在深夜赶稿时突然弹出的红色警告窗口打断了创作流程&#xff0c;或是重要演示前跳出的正版验证提示打乱了节奏——这些由Adobe Genuine Software Integrity Service&#xff08;简称AGSService&#xff09;引发的突发状况&…...

如何免费解锁WeMod专业版功能:完整教程与实战指南

如何免费解锁WeMod专业版功能&#xff1a;完整教程与实战指南 【免费下载链接】Wand-Enhancer Advanced UX and interoperability extension for Wand (WeMod) app 项目地址: https://gitcode.com/gh_mirrors/we/Wand-Enhancer 还在为WeMod专业版的高昂订阅费而烦恼吗&a…...

【实战解析】FTK Imager:被低估的取证级数据恢复利器

1. 被忽视的取证神器&#xff1a;FTK Imager实战初体验 第一次接触FTK Imager是在三年前的一个数据恢复案例中。当时客户送来一块行车记录仪的SD卡&#xff0c;里面存着一起交通事故的关键录像&#xff0c;但数据已被删除。我们尝试了市面上几乎所有主流恢复工具&#xff0c;结…...

直播设备ping值延时监测工具:功能详解与使用指南

对于直播从业者、网络运维人员来说&#xff0c;实时监测网络状态是个重要需求。本文介绍一款专门用于监测网络延时的工具&#xff0c;包含核心功能解析和参数设置建议。工具能做什么一句话总结&#xff1a;同时监测多台网络设备的延时情况&#xff0c;当延时超过阈值时报警&…...

如何突破Intel CPU性能瓶颈:智能电压调节工具的终极指南

如何突破Intel CPU性能瓶颈&#xff1a;智能电压调节工具的终极指南 【免费下载链接】Universal-x86-Tuning-Utility Unlock the full potential of your Intel/AMD based device. 项目地址: https://gitcode.com/gh_mirrors/un/Universal-x86-Tuning-Utility 你是否曾被…...

别再踩坑了!Unity 2019 + SteamVR 1.2.3 + VRTK 3.3.0 保姆级配置避坑指南

Unity 2019 SteamVR 1.2.3 VRTK 3.3.0 终极配置避坑手册 当你第一次尝试在Unity中配置VRTK进行VR开发时&#xff0c;可能会遇到各种令人抓狂的问题。从版本不兼容到脚本报错&#xff0c;从自动配置失效到莫名其妙的UI交互Bug&#xff0c;每一步都暗藏陷阱。本文将带你避开这些…...