news 2026/4/18 11:26:51

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/15 9:11:46

verl广告投放策略训练:ROI提升实战

verl广告投放策略训练&#xff1a;ROI提升实战 1. 技术背景与问题提出 在数字广告领域&#xff0c;如何通过智能化手段优化广告投放策略以最大化投资回报率&#xff08;ROI&#xff09;是企业长期关注的核心问题。传统基于规则或简单机器学习模型的投放系统难以应对动态变化的…

作者头像 李华
网站建设 2026/4/18 10:51:55

Fun-ASR-MLT-Nano-2512成本优化:GPU资源利用率提升

Fun-ASR-MLT-Nano-2512成本优化&#xff1a;GPU资源利用率提升 1. 引言 1.1 业务背景与挑战 随着多语言语音识别需求的快速增长&#xff0c;Fun-ASR-MLT-Nano-2512作为阿里通义实验室推出的轻量级大模型&#xff0c;凭借其800M参数规模和对31种语言的支持&#xff0c;在跨境…

作者头像 李华
网站建设 2026/4/18 10:51:28

零基础也能玩转AI绘画!UNet人像卡通化镜像保姆级教程

零基础也能玩转AI绘画&#xff01;UNet人像卡通化镜像保姆级教程 1. 学习目标与前置知识 本教程面向零基础用户&#xff0c;旨在帮助您快速掌握基于 UNet 架构的人像卡通化 AI 工具的完整使用流程。无论您是否具备编程或人工智能背景&#xff0c;只要按照本文步骤操作&#x…

作者头像 李华
网站建设 2026/4/18 5:05:33

部署麦橘超然后,我终于搞懂AI绘画怎么玩

部署麦橘超然后&#xff0c;我终于搞懂AI绘画怎么玩 1. 引言&#xff1a;从部署到理解&#xff0c;AI绘画的实践起点 在尝试了多个AI图像生成工具后&#xff0c;我最终选择了「麦橘超然 - Flux 离线图像生成控制台」作为我的本地创作入口。这不仅因为它支持中低显存设备运行&…

作者头像 李华
网站建设 2026/3/24 0:15:19

智能证件照工坊API文档:开发者快速入门

智能证件照工坊API文档&#xff1a;开发者快速入门 1. 引言 1.1 业务场景描述 在现代数字化办公与身份认证体系中&#xff0c;证件照是简历投递、考试报名、政务办理、平台注册等高频使用的核心材料。传统拍摄方式依赖照相馆或手动PS处理&#xff0c;流程繁琐且存在隐私泄露…

作者头像 李华
网站建设 2026/4/18 5:37:16

高效中文语音识别方案|FunASR WebUI镜像使用指南

高效中文语音识别方案&#xff5c;FunASR WebUI镜像使用指南 1. 快速开始与访问方式 1.1 启动服务与访问地址 在成功部署 FunASR 语音识别 WebUI 镜像后&#xff0c;系统将自动启动基于 Gradio 构建的可视化界面。用户可通过以下地址访问服务&#xff1a; http://localhost…

作者头像 李华