【Golang】LeetCode 206. 反转链表

206. 反转链表

题目描述

思路

这道题所提供的思路是解决 Hot 100 当中链表相关题目的模版,一定要确保好好理解。

反转链表,顾名思义,我们要做的就是将给定的链表进行翻转。题目当中的输入只有一个头节点,因此我们默认尾节点就是nil。我们定义两个节点,分别是currprev,来解决这个问题。

curr的含义是"当前节点",而prev的含义是"原链表当中在当前节点前面的那个节点"。我们要做的其实就是让currNext指向它的前一个节点prev,然后同时移动prev到当前的curr,并移动curr到它的下一个节点。

上面的思路说起来非常的容易,那么具体应该如何实现呢?我们可以对curr进行一个遍历,终止的条件就是curr == nil,每一次遍历开始时,令next := curr.Next,也就是显式地取出当前curr的下一个节点(因为我们即将在这次遍历时将currNext指针调整为prev,也就是它的前一个节点,以完成链表的翻转),然后我们调整curr.Next = prev,此时我们就完成了第一步,也就是翻转prevcurr的连接关系。

最后一步就是移动prevcurr,并移动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
}
相关推荐
让我上个超影吧15 小时前
【力扣26&80】删除有序数组中的重复项
算法·leetcode
漫随流水16 小时前
leetcode回溯算法(78.子集)
数据结构·算法·leetcode·回溯算法
全栈游侠17 小时前
数据结构 - 链表
数据结构·链表
We་ct17 小时前
LeetCode 151. 反转字符串中的单词:两种解法深度剖析
前端·算法·leetcode·typescript
wen__xvn17 小时前
代码随想录算法训练营DAY25第七章 回溯算法 part04
算法·leetcode·深度优先
June bug18 小时前
(#字符串处理)字符串中第一个不重复的字母
python·leetcode·面试·职场和发展·跳槽
AlenTech19 小时前
197. 上升的温度 - 力扣(LeetCode)
算法·leetcode·职场和发展
源代码•宸20 小时前
Leetcode—404. 左叶子之和【简单】
经验分享·后端·算法·leetcode·职场和发展·golang·dfs
WBluuue21 小时前
数据结构与算法:dp优化——优化尝试和状态设计
c++·算法·leetcode·动态规划
im_AMBER21 小时前
Leetcode 105 K 个一组翻转链表
数据结构·学习·算法·leetcode·链表