【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 分钟前
MySQL InnoDB 缓存池(Buffer Pool)详解:原理、结构与链表管理
java·数据结构·数据库·mysql·链表·缓存·面试
圣保罗的大教堂32 分钟前
leetcode 1594. 矩阵的最大非负积 中等
leetcode
重生之我是Java开发战士1 小时前
【广度优先搜索】队列:N叉树的层序遍历,二叉树的锯齿形层序遍历,二叉树的最大宽度,在每个树行中找最大值
数据结构·算法·leetcode·广度优先
zhoupenghui1681 小时前
redis 快速链表 详解
数据库·redis·链表·quicklist·快速链表
y = xⁿ2 小时前
【LeetCodehot100】T114:二叉树展开为链表 T105:从前序与中序遍历构造二叉树
java·算法·链表
灰色小旋风2 小时前
力扣20有效的括号(C++)
c++·算法·leetcode·职场和发展
逆境不可逃2 小时前
LeetCode 热题 100 之 160. 相交链表 206. 反转链表 234. 回文链表 141. 环形链表 142. 环形链表 II
算法·leetcode·链表
呆萌很2 小时前
【GO】if 语句练习题
golang
灰色小旋风2 小时前
力扣19删除链表的倒数第N个结点(C++)
c++·算法·leetcode·链表
lars_lhuan3 小时前
Go Mutex
golang