news 2026/5/1 8:50:24

【剑指Offer】026. 重排链表

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【剑指Offer】026. 重排链表

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

L0 → L1 → … → Ln-1 → Ln
请将其重新排列后变为:

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

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

/** * Definition for singly-linked list. * public class ListNode { * public int val; * public ListNode next; * public ListNode(int val=0, ListNode next=null) { * this.val = val; * this.next = next; * } * } */ public class Solution { public void ReorderList(ListNode head) { // 思路:将列表中的所有节点添加到栈中,每次插入时就从栈中取出 // 边界条件:head不能为null或者head.next不能为null if (head == null || head.next == null) return; // 将所有的节点压入栈中 Stack<ListNode> nodeStack = new Stack<ListNode>(); // 定义一个peekNode指向栈顶节点 ListNode peekNode = head; while (peekNode != null) { nodeStack.Push(peekNode); peekNode = peekNode.next; } peekNode = nodeStack.Peek(); // 定义一个preNode指向当前的前一个执行了插入的节点,初值为null ListNode preNode = null; // 定义一个nextNode指向下一个需要执行插入的节点,初值为head ListNode nextNode = head; // 临时节点 ListNode tmpNode = null; // 进行一个while循环,循环条件为preNode不能等于栈顶节点或者nextNode不能等于栈顶节点 while ( preNode != peekNode && nextNode != peekNode) { tmpNode = nextNode.next != peekNode ? nextNode.next : null; // 执行插入操作 preNode = nextNode; nextNode.next = peekNode; peekNode.next = tmpNode; nodeStack.Pop(); peekNode = nodeStack.Peek(); nextNode = tmpNode; } // 质空尾部 if(nextNode != null) nextNode.next = null; } }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/22 12:14:19

【毕业设计】卷神经网络基于python深度学习的餐桌美食识别

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

作者头像 李华
网站建设 2026/4/24 15:07:32

开题报告卡壳?paperzz 开题报告:连 PPT 都能一键生成的智能写作工具

Paperzz-AI官网免费论文查重复率AIGC检测/开题报告/文献综述/论文初稿 paperzz - 开题报告https://www.paperzz.cc/proposal 对于硕士研究生来说&#xff0c;开题报告的 “难” 不止是写文字 —— 还要搭逻辑框架、凑够字数、匹配学校格式&#xff0c;甚至得做一份能讲清楚思…

作者头像 李华
网站建设 2026/4/25 21:47:03

天下工厂平台在数据隐私安全方面是如何提供保障的?

在B2B数据服务这个领域&#xff0c;用户常常会有这样的疑问&#xff1a;“要是提供了老板的手机号&#xff0c;是不是就会出现隐私泄露的问题?”针对这样的疑问&#xff0c;“天下工厂”平台自始至终都秉持着合法、公开、必要、最小化这四个重要原则&#xff0c;以此来保证数据…

作者头像 李华
网站建设 2026/4/30 11:24:03

工业CV项目AI部署方案模板

工业CV项目AI部署方案模板 文档版本&#xff1a;V1.0 编制日期&#xff1a;【YYYY-MM-DD】 适用场景&#xff1a;【如机器人3D无序抓取、高精度视觉定位、手眼标定引导、在线缺陷检测等】 文档用途&#xff1a;项目立项、方案评审、客户交付、部署实施指导 一、项目概述 1.1 项…

作者头像 李华