【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
}
相关推荐
羊羊羊i18 分钟前
使用client-go访问k8s集群
golang·kubernetes
im_AMBER28 分钟前
Leetcode 95 分割链表
数据结构·c++·笔记·学习·算法·leetcode·链表
源代码•宸42 分钟前
goframe框架签到系统项目开发(实现总积分和积分明细接口、补签日期校验)
后端·golang·postman·web·dao·goframe·补签
梭七y1 小时前
【力扣hot100题】(121)反转链表
算法·leetcode·链表
黎雁·泠崖1 小时前
【线性表系列入门篇】从顺序表到链表:解锁数据结构的进化密码
c语言·数据结构·链表
AD钙奶-lalala1 小时前
leetcode核心母题总结
算法·leetcode·职场和发展
YGGP1 小时前
【Golang】LeetCode 2. 两数相加
开发语言·leetcode·golang
Yy_Yyyyy_zz1 小时前
2025 技术年终总结|近七年 Golang 工程实践、AI 应用落地与技术创作回顾
开发语言·golang·ai编程
努力学算法的蒟蒻1 小时前
day53(1.4)——leetcode面试经典150
算法·leetcode·面试
GrowingYi1 小时前
Go语言的特性
开发语言·后端·golang