206. 反转链表

题目描述

思路
这道题所提供的思路是解决 Hot 100 当中链表相关题目的模版,一定要确保好好理解。
反转链表,顾名思义,我们要做的就是将给定的链表进行翻转。题目当中的输入只有一个头节点,因此我们默认尾节点就是nil。我们定义两个节点,分别是curr和prev,来解决这个问题。
curr的含义是"当前节点",而prev的含义是"原链表当中在当前节点前面的那个节点"。我们要做的其实就是让curr的Next指向它的前一个节点prev,然后同时移动prev到当前的curr,并移动curr到它的下一个节点。
上面的思路说起来非常的容易,那么具体应该如何实现呢?我们可以对curr进行一个遍历,终止的条件就是curr == nil,每一次遍历开始时,令next := curr.Next,也就是显式地取出当前curr的下一个节点(因为我们即将在这次遍历时将curr的Next指针调整为prev,也就是它的前一个节点,以完成链表的翻转),然后我们调整curr.Next = prev,此时我们就完成了第一步,也就是翻转prev和curr的连接关系。
最后一步就是移动prev到curr,并移动curr到它的下一个节点,完成最后一步本次循环即可结束,处理下一次迭代即可。如何完成这一步呢?其实到此为止答案已经非常明显了,那就是令prev, curr = curr, next。
最后我们需要返回翻转后链表的头节点,实际上就是prev。
基于以上思路,我们写代码来解决这道题。
Golang 题解
go
/**
* Definition for singly-linked list.
* type ListNode struct {
* Val int
* Next *ListNode
* }
*/
func reverseList(head *ListNode) *ListNode {
curr, prev := head, (*ListNode)(nil)
for curr != nil {
next := curr.Next
curr.Next = prev
prev = curr
curr = next
}
return prev
}