/**
* Definition for singly-linked list.
* class ListNode {
* int val;
* ListNode next;
* ListNode(int x) {
* val = x;
* next = null;
* }
* }
*/
public class Solution {
public void reorderList(ListNode head) {
ListNode fast = head;
ListNode slow = head;
while (fast!=null && fast.next!=null) {
fast = fast.next.next;
slow = slow.next;
}
ListNode preReverse = slow;
if (preReverse==null) return;
ListNode preHead = preReverse.next;
if (preHead==null) return;
ListNode preCur = preHead.next;
ListNode cur = preHead.next;
preHead.next = null;
while (cur!=null) {
cur = cur.next;
preCur.next = preHead;
preHead = preCur;
preCur = cur;
}
preReverse.next = preHead;
preReverse.next = null;
cur = head;
while (cur!=null && preHead!=null) {
ListNode temp = cur.next;
cur.next = preHead;
preHead = preHead.next;
cur.next.next = temp;
cur = temp;
}
}
}
没有评论:
发表评论