1、迭代
我们可以迭代的查找每一个节点,将原先指向下一个节点的指针指向上一个节点。
class Solution {
public:
ListNode* reverseList(ListNode* head) {
ListNode* prev = nullptr;
ListNode* curr = head;
while (curr) {
ListNode* next = curr->next;
curr->next = prev;
prev = curr;
curr = next;
}
return prev;
}
};
2、递归
我们可以递归的调用函数返回其反转后的节点。当当前节点为空或指向空指针时,我们返回当前节点。我们假设当前节点之后的节点都已经反转完成,此时我们需要将当前节点之后一个节点的next指针指向当前节点,并将当前节点的next指针指向空指针。
class Solution {
public:
ListNode* reverseList(ListNode* head) {
if (!head || !head->next) {
return head;
}
ListNode* newHead = reverseList(head->next);
head->next->next = head;
head->next = nullptr;
return newHead;
}
};