news 2026/5/1 4:41:49

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/5/1 5:45:28

BGE-Reranker-v2-m3调用延迟高?异步处理优化方案详解

BGE-Reranker-v2-m3调用延迟高&#xff1f;异步处理优化方案详解 1. 问题背景与技术挑战 在构建高性能检索增强生成&#xff08;RAG&#xff09;系统时&#xff0c;BGE-Reranker-v2-m3 模型作为提升召回结果相关性的关键组件&#xff0c;广泛应用于对初步检索出的文档进行精细…

作者头像 李华
网站建设 2026/5/1 5:44:05

NotaGen技术解析:古典音乐生成的模型架构

NotaGen技术解析&#xff1a;古典音乐生成的模型架构 1. 引言 1.1 技术背景与问题提出 随着深度学习在序列建模领域的持续突破&#xff0c;大型语言模型&#xff08;LLM&#xff09;范式已不再局限于自然语言处理任务。近年来&#xff0c;研究者开始探索将LLM应用于符号化音…

作者头像 李华
网站建设 2026/3/27 21:20:49

Z-Image-Turbo vs 其他文生图模型:速度与质量对比

Z-Image-Turbo vs 其他文生图模型&#xff1a;速度与质量对比 1. 引言&#xff1a;文生图模型的效率之争 近年来&#xff0c;文本生成图像&#xff08;Text-to-Image&#xff09;技术取得了飞速发展&#xff0c;Stable Diffusion、DALLE 系列、Midjourney 等模型不断刷新人们…

作者头像 李华
网站建设 2026/5/1 6:56:08

Qwen1.5-0.5B应用创新:教育领域的智能辅导系统案例

Qwen1.5-0.5B应用创新&#xff1a;教育领域的智能辅导系统案例 1. 引言&#xff1a;轻量模型驱动的教育智能化转型 随着人工智能技术在教育领域的不断渗透&#xff0c;个性化学习与智能辅导系统正逐步成为教学改革的重要方向。然而&#xff0c;传统AI辅助系统往往依赖多模型协…

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

GPEN是否支持Windows?WSL2环境部署可行性测试

GPEN是否支持Windows&#xff1f;WSL2环境部署可行性测试 1. 镜像环境说明 组件版本核心框架PyTorch 2.5.0CUDA 版本12.4Python 版本3.11推理代码位置/root/GPEN 主要依赖库&#xff1a; facexlib: 用于人脸检测与对齐basicsr: 基础超分框架支持opencv-python, numpy<2.…

作者头像 李华
网站建设 2026/5/1 5:46:05

Open-AutoGLM娱乐应用:AI自动刷短视频并点赞优质内容

Open-AutoGLM娱乐应用&#xff1a;AI自动刷短视频并点赞优质内容 1. 引言 1.1 技术背景与应用场景 随着移动互联网的普及&#xff0c;用户每天在短视频平台&#xff08;如抖音、快手、小红书&#xff09;上花费大量时间进行内容浏览、互动和社交。然而&#xff0c;重复性操作…

作者头像 李华