LeetCode206.反转链表
题目
给你单链表的头节点 head ,请你反转链表,并返回反转后的链表。
输入: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.com/problems/reverse-linked-list 著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
解题思路
采用迭代方式完成反转
1->2->3->4->5
设置两个变量: 存储上一个节点 prev,存储当前节点 curr
直到当前节点为空时结束循环:
循环内逻辑: 定义next保存当前节点的下一个节点
当前节点指向上一个节点
上一个节点变成当前节点
当前节点变成下一个节点
最后返回赋值为最后一个节点的变量prev即可
采用递归方式完成反转
当前节点为空或已经指向到最后一个节点时结束递归,返回当前节点。
否则将下一个节点往下递,
归的过程:将当前节点的下一个节点指向当前节点,将当前节点的指针指向空
返回新链表头节点
代码
// 迭代方式 时间复杂度为O(n) n为链表长度 空间复杂度为 O(1)
func reverseList(head *ListNode) *ListNode {
// 存储上一个节点,初始化为空
var prev *ListNode
// 当前节点
curr := head
for curr != nil {
// 存储下一个节点
next := curr.Next
// 将当前节点指向上一个节点
curr.Next = prev
// 将当前节点作为上一个节点
prev = curr
// 将下一个节点作为当前节点
curr = next
// 赋值简写 curr.Next,prev,curr = prev,curr,curr.Next
}
// 返回结果为上一个节点变量,因为当前节点变量指向为空
return prev
}
// 递归方式 时间复杂度 O(n) 空间复杂度 O(n)
func reverseList2(head *ListNode) *ListNode {
// 终止条件,当前节点为空或指向到最后一个节点
if head == nil || head.Next == nil{
return head
}
// 递
newHead := reverseList2(head.Next)
// 归 将当前节点的下一个节点指向当前节点
head.Next.Next = head
// 将当前节点指向空
head.Next = nil
return newHead
}