递归法
递归版本稍微复杂一些,其关键在于反向工作。假设列表的其余部分已经被反转,现在我该如何反转它前面的部分?
假设列表为:
n1→…→nk−1→nk→nk+1→…→nm→∅
若从节点 nk+1 到 nm 已经被反转,而我们正处于 nk。
n1→…→nk−1→nk→nk+1←…←nm
我们希望 nk+1 的下一个节点指向 nk。
所以,nk.next.next = nk。
要小心的是 n1的下一个必须指向 Ø 。如果你忽略了这一点,你的链表中可能会产生循环。如果使用大小为 2 的链表测试代码,则可能会捕获此错误。
ListNode* reverseList(ListNode* head) {
/*迭代
ListNode* pre=NULL;
ListNode* cur=head;
while(cur!=NULL){
ListNode* temp = cur->next;
cur->next=pre;
pre=cur;
cur=temp;
}
return pre;
*/
//递归
if (head == null || head.next == null) return head;
ListNode p = reverseList(head.next);
head.next.next = head;//关键思想
head.next = null;
return p;
}