难度: 简单
题目: 给你单链表的头节点 head ,请你反转链表,并返回反转后的链表。
解题:
迭代
采用双指针的方式思路,分别用来记录前一个指针和后一个指针,每次遍历将当前节点的next指向前一个节点。
class Solution {
public:
ListNode* reverseList(ListNode* head) {
ListNode* prev = nullptr;
ListNode* next = nullptr;
while (head) {
next = head->next;
head->next = prev;
prev = head;
head = next;
}
return prev;
}
};
递归
每一次递归都看作是将其余的链表进行反转,递归到最后的时候,即只剩下最后一个节点,就是最终的头节点。
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;
}
};