/** * Definition for singly-linked list. * type ListNode struct { * Val int * Next *ListNode * } */ funcreorderList(head *ListNode) { if head == nil || head.Next == nil { return }
// 寻找中间结点 p1 := head p2 := head for p2.Next != nil && p2.Next.Next != nil { p1 = p1.Next p2 = p2.Next.Next }
// 反转链表后半部分 1->2->3->4->5->6 to 1->2->3->6->5->4 preMiddle := p1 preCurrent := p1.Next for preCurrent.Next != nil { current := preCurrent.Next preCurrent.Next = current.Next current.Next = preMiddle.Next preMiddle.Next = current }