【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
}
相关推荐
x_xbx2 分钟前
LeetCode:5. 最长回文子串
算法·leetcode·职场和发展
程序员卷卷狗9 分钟前
Java转Go面试速记:Go基础22问,一篇理清高频易错点一篇理清高频易错点
java·面试·golang
会编程的土豆2 小时前
Go interface 底层的 itab 到底是什么
开发语言·后端·golang
小欣加油4 小时前
leetcode 3300 替换为数位和后的最小元素
数据结构·c++·算法·leetcode
人道领域4 小时前
【LeetCode刷题日记】108.将有序数组转换为二叉搜索树
java·算法·leetcode
过期动态5 小时前
【LeetCode 热题 100】无重复字符的最长子串
java·数据结构·spring boot·算法·leetcode·职场和发展
莫等闲-6 小时前
leetcode42. 接雨水 leetcode84.柱状图中最大的矩形
数据结构·c++·算法·leetcode
浅念-6 小时前
LeetCode 记忆化搜索 刷题总结
数据结构·算法·leetcode·职场和发展·深度优先·dfs
non-action_pilgrim6 小时前
Go 高并发踩坑:关于在 for 循环里使用 time.After 后所进行的问题分析
golang
菜菜的顾清寒6 小时前
力扣HOT100(44)对称二叉树
数据结构·算法·leetcode