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;     } }

相关内容

热门资讯

两分钟了解(朋朋棋牌)外挂透明... 自定义新版朋朋棋牌系统规律,只需要输入自己想要的开挂功能,一键便可以生成出朋朋棋牌专用辅助器,不管你...
每日必备!乐清麻将花到底有挂,... 《乐清麻将花到底有挂软件透明挂》是一款多人竞技的乐清麻将花到底有挂辅助透视游戏,你将微扑克对手来到同...
二分钟了解(桃乐甘肃麻将)外挂... 二分钟了解(桃乐甘肃麻将)外挂透明挂辅助开挂(透视)其实有挂是真的(有挂总结)-哔哩哔哩;德扑锦标赛...
重大科普!奇迹陕西棋牌有挂的,... 重大科普!奇迹陕西棋牌有挂的,透视!原来真的有挂的(竟然有挂)-哔哩哔哩;德扑锦标赛是一项奇迹陕西棋...
一分钟了解(掌中乐游戏中心云南... 一分钟了解(掌中乐游戏中心云南)外挂透明挂辅助软件,其实是真的有挂(有挂总结)-哔哩哔哩;掌中乐游戏...
4分钟了解(内蒙古圈)外挂透明... 4分钟了解(内蒙古圈)外挂透明挂辅助挂(透视)原来到底真的有辅助挂(有挂打法)-哔哩哔哩;1、让任何...
二分钟了解(中至景德镇麻将)外... 《中至景德镇麻将软件透明挂》是一款多人竞技的中至景德镇麻将辅助透视游戏,你将微扑克对手来到同一个战场...
一分钟了解(朋友安徽麻将)外挂... 一分钟了解(朋友安徽麻将)外挂透明挂辅助软件(透视)原来到底是真的有辅助挂(有挂总结)-哔哩哔哩;朋...
四分钟了解(天天仁怀)外挂透明... 您好,天天仁怀这款游戏可以开挂的,确实是有挂的,需要了解加微【841106723】很多玩家在这款游戏...
查到实测!娱网皮球填大坑有挂的... 查到实测!娱网皮球填大坑有挂的,辅助!确实真的有挂(有挂教学)-哔哩哔哩;致您一封信;亲爱娱网皮球填...