题目
给你单链表的头节点 head ,请你反转链表,并返回反转后的链表。
示例 1:
输入:head = [1,2,3,4,5]
输出:[5,4,3,2,1]
示例 2:
输入:head = [1,2]
输出:[2,1]
示例 3:
输入:head = []
输出:[]
提示:
链表中节点的数目范围是 [0, 5000]
-5000 <= Node.val <= 5000
来源:力扣(LeetCode)
链接:https://leetcode.cn/problems/reverse-linked-list
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
思路
- 其实就是迭代在加上一个双指针就没有了
- 然后那个递归暂时还不会,等以后会了,在继续补上去。
代码(迭代+双指针)
/**
* Definition for singly-linked list.
* struct ListNode {
* int val;
* struct ListNode *next;
* };
*/
struct ListNode* reverseList(struct ListNode* head){
if(head==NULL||head->next==NULL)
{
return head;
}
struct ListNode* slow=NULL;
struct ListNode* fast=head;
while(fast!=NULL)
{
struct ListNode* t=fast->next;
fast->next=slow;
slow=fast;
fast=t;
}
return slow;
}
递归
- 有大佬可以讲讲这题用递归该怎么做呀。