题目描述
给定一个单链表 L 的头节点 head ,单链表 L 表示为:
L0 → L1 → … → Ln - 1 → Ln
请将其重新排列后变为:
L0 → Ln → L1 → Ln - 1 → L2 → Ln - 2 → …
不能只是单纯的改变节点内部的值,而是需要实际的进行节点交换。
样例描述
思路
分解成三个部分,
- 快慢指针法找到链表中点
- 翻转后半部分的链表
- 对前半部分和翻转后的后半部分进行拼接形成新的链表,拼接用尾插的思路,给两个链表都设置一个移动指针,不断往后面移动。 防止断链
- 细节:翻转链表后,原来的头结点要指向null
代码
/**
* 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 || he