LeetCode206,直接看下面链接的动画演示部分就行了,就能快速理解pre和cur的作用
代码随想录:反转链表
这个是另外的在B站的视频讲解链接
【帮你拿下反转链表 | LeetCode:206.反转链表 | 双指针法 | 递归法】 https://www.bilibili.com/video/BV1nB4y1i7eL/?share_source=copy_web\&vd_source=afbacdc02063c57e7a2ef256a4db9d2a
cpp
class Solution {
public:
ListNode* reverseList(ListNode* head) {
ListNode* pre=nullptr,*cur=nullptr,*tmp=nullptr;
cur=head;
while(cur!=nullptr){
tmp=cur->next;
cur->next=pre;
pre=cur;
cur=tmp;
}
return pre;
}
};
递归方法:
具体运行过程是在倒数第二个节点反转倒数第一个节点的next指针指向,然后返回最后一个节点的指针,注意,这个递归每次返回的都是倒数第一个的节点的指针,否则这题无法使用递归完成.
cpp
class Solution {
public:
ListNode* reverseList(ListNode* head) {
if(head==nullptr||head->next==nullptr){
return head;
}
ListNode* newHead=reverseList(head->next);
head->next->next=head;
head->next=nullptr;
return newHead;
}
};