定义一个函数,输入一个链表的头节点,反转该链表并输出反转后链表的头节点。
示例:
输入: 1->2->3->4->5->NULL 输出: 5->4->3->2->1->NULL
限制:
0 <= 节点个数 <= 5000
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/fan-zhuan-lian-biao-lcof
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
解题思路
1.迭代法
声明两个指针
/**
* Definition for singly-linked list.
* struct ListNode {
* int val;
* ListNode *next;
* ListNode(int x) : val(x), next(NULL) {}
* };
*/
class Solution {
public:
ListNode* reverseList(ListNode* head) {
ListNode*cur=NULL,*pre=head;
while(pre)
{
ListNode* temp=pre->next;//存储下一个位置
pre->next=cur;//后指针指向前指针
cur=pre;//前指针后移
pre=temp;//后指针后移
}
return cur;
}
};
2.递归法
先递归至倒数第二个节点处,让最后一个节点指向倒数第二个,然后倒数第二个指向null
/**
* Definition for singly-linked list.
* struct ListNode {
* int val;
* ListNode *next;
* ListNode(int x) : val(x), next(NULL) {}
* };
*/
class Solution {
public:
ListNode* reverseList(ListNode* head) {
if(!head||!head->next)//递归终止
{
return head;
}
ListNode*root=reverseList(head->next);//到最后
head->next->next=head;
head->next=NULL;
return root;
}
};