【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
}
相关推荐
语戚7 小时前
力扣 968. 监控二叉树 —— 贪心 & 树形 DP 双解法递归 + 非递归全解(Java 实现)
java·算法·leetcode·贪心算法·动态规划·力扣·
skywalker_117 小时前
力扣hot100-7(接雨水),8(无重复字符的最长子串)
算法·leetcode·职场和发展
hrhcode8 小时前
【java工程师快速上手go】二.Go进阶特性
java·golang·go
田梓燊9 小时前
leetcode 160
算法·leetcode·职场和发展
_深海凉_9 小时前
LeetCode热题100-颜色分类
python·算法·leetcode
6Hzlia9 小时前
【Hot 100 刷题计划】 LeetCode 136. 只出现一次的数字 | C++ 哈希表&异或基础解法
c++·算法·leetcode
Tomhex10 小时前
Go字符串拼接最佳实践
golang·go
zs宝来了11 小时前
Go 内存管理:三色标记 GC 与逃逸分析
golang·go·后端技术
无限进步_11 小时前
【C++】只出现一次的数字 II:位运算的三种解法深度解析
数据结构·c++·ide·windows·git·算法·leetcode
_深海凉_12 小时前
LeetCode热题100-找到字符串中所有字母异位词
算法·leetcode·职场和发展