Leetcode-高频面试题-143.重排链表
创始人
2024-09-25 21:23:12
0

 解法都在代码里,不懂就留言或者私信

/**  * Definition for singly-linked list.  * public class ListNode {  *     int val;  *     ListNode next;  *     ListNode() {}  *     ListNode(int val) { this.val = val; }  *     ListNode(int val, ListNode next) { this.val = val; this.next = next; }  * }  */ class Solution {     /**本题基本思路:先把链表分为前半部分和后半部分,如果不是偶数就前半部分多一个     然后把后半部分逆序,然后前后一个一个的交替连接*/     public void reorderList(ListNode head) {         if(head == null || head.next == null) {             return;         }         /**先过一下链表统计一下节点数 */         int count = 0;         ListNode cur = head;         while(cur != null) {             count ++;             cur = cur.next;         }         /**把cur恢复成指向head*/         cur = head;         /**count变成(count-1)/2 */         count = (count - 1)/2;         while(count > 0) {             cur = cur.next;             count --;         }         /**出while循环的时候cur指向的是左边部分的终点,现在开始分离链表的工作 */         ListNode rightHead = cur.next;         cur.next = null;         /**再次把cur恢复成head */         cur = head;         rightHead = reverse(rightHead);         /**head肯定是要作为头的,我们现在要用一个left指针指向head的下个节点(左边部分的下一个节点) */         ListNode left = head.next;         ListNode right = rightHead;         /**当前已经串起来的最后一个节点 */         ListNode curNode = head;         while(left != null) {             /**每次循环我们只处理两个数,先连右边部分下一个,然后右边部分下一个指向左边下一个             这个过程就造成了右边部分下一个指针发生变化,需要提前存一下,左边部分是我们串的最后一个节点             它的next不变,不用执行这个操作 */             ListNode rightNext = right.next;             /**之前最后一个节点(来自左边)连接右边下一个节点 */             curNode.next = right;             /**右边下一个的next指向左边下一个 */             right.next = left;             /**本次循环的最后一个节点作为curNode(最后一个被串起来的节点) */             curNode = left;             /**左右都跳下一个 */             right = rightNext;             left = left.next;             }         /**如果没有用完,只能是右边没有用完 */         if(right != null) {             curNode.next = right;             right.next = null;         }     }     /**经典面试题-反转链表 */     public ListNode reverse(ListNode head) {         ListNode cur = head;         ListNode pre = null;         ListNode next = null;         while(cur != null) {             next = cur.next;             cur.next = pre;             pre = cur;             cur = next;         }         return pre;     } }

相关内容

热门资讯

第九分钟辅助!天天爱柳州辅助器... 天天爱柳州辅助器是一款可以让一直输的玩家,快速成为一个“必胜”的ai辅助神器,有需要的用户可以加我微...
热门推荐!微信小程序蜀山辅助器... 热门推荐!微信小程序蜀山辅助器免费下载(辅助)外挂辅助开挂插件(有挂秘诀)-哔哩哔哩;最新版2026...
第4分钟普及!奇迹陕西辅助器(... 第4分钟普及!奇迹陕西辅助器(透视)原来真的是有挂脚本(推荐开挂软件);奇迹陕西辅助器免费下载原版,...
第八分钟讲解!越乡游金花辅助,... 第八分钟讲解!越乡游金花辅助,九酷众游辅助,细节方法(有挂实锤)-哔哩哔哩1、下载安装好越乡游金花辅...
透视软件!浙江宝宝游戏辅助工具... 透视软件!浙江宝宝游戏辅助工具(辅助)外挂开挂辅助插件(了解有挂)-哔哩哔哩;是一款可以让一直输的玩...
第5分钟发现!桃乐甘肃麻将下载... 《第5分钟发现!桃乐甘肃麻将下载辅助器(辅助)原来有挂软件(必看开挂工具)》 桃乐甘肃麻将下载辅助器...
第8分钟了解!河洛刚次辅助,温... 第8分钟了解!河洛刚次辅助,温州茶苑辅助软件,详细教程(有挂攻略)-哔哩哔哩;无需打开直接搜索加薇1...
热点讨论!新二号辅助软件下载(... 热点讨论!新二号辅助软件下载(辅助)外挂辅助开挂软件(有挂教程)-哔哩哔哩;是一款可以让一直输的玩家...
8分钟解说!网易亲友圈辅助(开... 8分钟解说!网易亲友圈辅助(开挂)原来有挂平台(必看开挂安装);小薇(透视辅助)致您一封信;亲爱网易...
第5分钟开挂!如何在哈灵上辅助... 第5分钟开挂!如何在哈灵上辅助,决战卡五星辅助看牌器,解说技巧(有挂方略)-哔哩哔哩 了解更多开挂安...