news 2026/4/23 8:22:26

【剑指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/23 8:20:19

Shiro漏洞利用工具,更新V0.2!

工具介绍 Shiro漏洞利用工具&#xff0c;更新ShiroEXP V0.2工具功能 爆破key及加密方式(已完成)漏洞探测(已完成Shiro550 URLDNS探测)探测回显链(已完成CB1TomcatEcho、Spring、AllEcho回显链)漏洞利用(已完成命令执行、Shell模式)注入内存马(支持蚁剑、冰蝎、哥斯拉等filter、…

作者头像 李华
网站建设 2026/4/16 19:49:16

CSDN资源等级如何提升?综合贡献分如何提高?

长话短说&#xff0c;只有三种方式可以提升综合贡献分。方式一&#xff1a;完成成长任务完成此处的成长任务&#xff0c;通过审核即可增加综合贡献分&#xff0c;这个每天不限量&#xff0c;完成多少都可以&#xff0c;但是每个任务只能完成一次。方式二&#xff1a;完成热点任…

作者头像 李华