假如链表结构:A->B->C->D->E->F->G
prve = A
curr = B
curr.next = prve
prve = A
curr = B
// 先记录,后指向
temp = curr.next
curr.next = prve
prve = curr
curr = temp
public static ListNode reverseList(ListNode head) {
    ListNode prve = null;
    ListNode curr = head;
    ListNode next = null;
    while (curr != null){
        //反指
        next = curr.next;
        curr.next = prve;
        //下一个
        prve = curr;
        curr = next;
    }
    return prve;
}
原文:https://www.cnblogs.com/inkyi/p/15001598.html