news 2026/4/23 20:42:16

day136—快慢指针—重排链表(LeetCode-143)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
day136—快慢指针—重排链表(LeetCode-143)

题目描述

给定一个单链表L的头节点head,单链表L表示为:

L0 → L1 → … → Ln - 1 → Ln

请将其重新排列后变为:

L0 → Ln → L1 → Ln - 1 → L2 → Ln - 2 → …

不能只是单纯的改变节点内部的值,而是需要实际的进行节点交换。

示例 1:

输入:head = [1,2,3,4]输出:[1,4,2,3]

示例 2:

输入:head = [1,2,3,4,5]输出:[1,5,2,4,3]

提示:

  • 链表的长度范围为[1, 5 * 104]
  • 1 <= node.val <= 1000

解决方案:

这段代码的核心功能是重排单链表(将链表调整为「原链表前半部分节点 + 后半部分反转后的节点」交替拼接的形式,比如原链表 1→2→3→4→5 变为 1→5→2→4→3,1→2→3→4 变为 1→4→2→3),通过「找中点 + 反转后半段 + 交替拼接」三步实现,时间复杂度O(n)、空间复杂度O(1),是该问题的最优解法。

核心逻辑

代码整合了 “找链表中点”“反转链表” 两个基础操作,再通过双指针交替拼接完成重排,全程无额外空间开销:

  1. 第一步:找链表中点:调用midNode函数(快慢指针法)找到链表中间节点mid,将原链表拆分为前半段(head开头)和后半段(mid开头);
  2. 第二步:反转后半段:调用reverseNode函数反转后半段链表,得到反转后的后半段头节点head2
  3. 第三步:交替拼接:用两个指针分别遍历前半段和反转后的后半段,逐个将后半段节点插入前半段节点之间,直到后半段只剩最后一个节点(避免链表成环),完成重排。

总结

  1. 核心思路:将重排问题拆解为 “找中点拆分 + 反转后半段 + 交替拼接” 三个基础链表操作,化繁为简;
  2. 关键细节:拼接时循环条件为head2->next(而非head2),避免最后拼接导致链表闭环;
  3. 效率优势:三步操作均为一次遍历,整体时间O(n)、空间O(1),是重排链表的最优解法。

函数源码:

/** * Definition for singly-linked list. * struct ListNode { * int val; * ListNode *next; * ListNode() : val(0), next(nullptr) {} * ListNode(int x) : val(x), next(nullptr) {} * ListNode(int x, ListNode *next) : val(x), next(next) {} * }; */ class Solution { public: //找中间结点——快慢指针 ListNode* midNode(ListNode* head){ ListNode* slow=head; ListNode* fast=head; while(fast && fast->next){ slow=slow->next; fast=fast->next->next; } return slow; } //反转链表 ListNode* reverseNode(ListNode* head){ ListNode* pre=nullptr; ListNode* cur=head; ListNode* nxt=nullptr; while(cur){ nxt=cur->next; cur->next=pre; pre=cur; cur=nxt; } return pre; } void reorderList(ListNode* head) { ListNode* mid =midNode(head); ListNode* head2=reverseNode(mid); ListNode* nxt=nullptr; ListNode* nxt2=nullptr; while(head2->next){ nxt=head->next; nxt2=head2->next; head->next=head2; head2->next=nxt; head=nxt; head2=nxt2; } } };
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/23 17:23:23

AutoGLM-Phone-9B启动与调用详解|从环境配置到API测试全流程

AutoGLM-Phone-9B启动与调用详解&#xff5c;从环境配置到API测试全流程 1. 引言&#xff1a;移动端多模态大模型的应用前景 随着边缘计算和终端智能的快速发展&#xff0c;将大语言模型部署至资源受限设备已成为AI落地的重要方向。AutoGLM-Phone-9B 正是在这一背景下推出的专…

作者头像 李华
网站建设 2026/4/23 15:36:57

Supertonic部署优化:Docker容器化方案实践

Supertonic部署优化&#xff1a;Docker容器化方案实践 1. 引言 1.1 业务场景与技术背景 在边缘计算和隐私敏感型应用日益增长的背景下&#xff0c;设备端文本转语音&#xff08;TTS&#xff09;系统成为关键基础设施。传统云服务驱动的TTS方案虽然功能丰富&#xff0c;但存在…

作者头像 李华
网站建设 2026/4/23 14:07:14

实战案例:一名新手如何恢复失灵的STLink

从“STLink识别不出来”到成功烧录&#xff1a;一个新手的救砖实录 你有没有过这样的经历&#xff1f; 刚打开电脑准备调试STM32&#xff0c;结果STM32CubeIDE弹出一句&#xff1a;“No ST-Link detected”。 设备管理器里一片空白&#xff0c;USB插了拔、拔了再插&#xff…

作者头像 李华
网站建设 2026/4/23 11:22:59

从ENCODE到植物pENCODE:表观图谱正当时,附数据库盘点

2003年&#xff0c;人类基因组计划的完成被誉为生命科学的登月工程。它为我们提供了一份包含了30亿个碱基对的线性参照序列。然而&#xff0c;随着香槟庆祝的泡沫散去&#xff0c;科研界迅速面临了一个更深层的困惑&#xff1a;在这一庞大的序列中&#xff0c;编码蛋白质的基因…

作者头像 李华
网站建设 2026/4/23 12:54:20

YOLO11部署教程:企业级视觉系统构建的起点与路径

YOLO11部署教程&#xff1a;企业级视觉系统构建的起点与路径 YOLO11是目标检测领域最新一代的高效算法演进成果&#xff0c;延续了YOLO系列“实时性高精度”的核心设计理念&#xff0c;并在模型结构、特征融合机制和训练策略上进行了多项创新。相比前代版本&#xff0c;YOLO11…

作者头像 李华
网站建设 2026/4/23 12:59:20

docker部署数据中台系统DataCap

推荐一套基于 SpringBoot 开发的简单、易用的开源权限管理平台&#xff0c;建议下载使用: https://github.com/devlive-community/authx 推荐一套为 Java 开发人员提供方便易用的 SDK 来与目前提供服务的的 Open AI 进行交互组件&#xff1a;https://github.com/devlive-commun…

作者头像 李华