”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > go 中反转链表

go 中反转链表

发布于2024-07-31
浏览:518

Reverse a linked list in go

这是新开发人员最喜欢提出的问题。如果你有一个像样的数据结构课程,那就很简单了。

反转单链表。 (这是 Leetcode 206)

为了实现,我选择将链表设为泛型类型。

type Node[T any] struct {
    Data T
    Next *Node[T]
}

type LinkedList[T any] struct {
    Head *Node[T]
}

func (ll *LinkedList[T]) Append(data T) {
    newNode := &Node[T]{Data: data, Next: nil}

    if ll.Head == nil {
        ll.Head = newNode
        return
    }

    current := ll.Head
    for current.Next != nil {
        current = current.Next
    }
    current.Next = newNode
}

对于反向函数,通过认识到我们需要做的就是维护指向前一个节点的指针,然后将给定节点的“下一个”设置为前一个节点,只需一次传递即可完成。

当我们到达末尾时,我们就知道当前节点是列表的新“头”。

func (ll *LinkedList[T]) ReverseLinkedList() {
    var prev *Node[T] = nil
    var ptr *Node[T] = ll.Head
    for ptr != nil {
        var next *Node[T] = ptr.Next
        ptr.Next = prev
        prev = ptr
        if next == nil {
            ll.Head = ptr
        }
        ptr = next
    }
}

我们是否错过了边界条件?如果列表现在是双向链表,会增加哪些复杂性?请在评论中告诉我。

谢谢!

这篇文章以及本系列所有文章的代码可以在这里找到

版本声明 本文转载于:https://dev.to/johnscode/reverse-a-linked-list-in-go-583i?1如有侵犯,请联系[email protected]删除
最新教程 更多>
  • 如何限制动态大小的父元素中元素的滚动范围?
    如何限制动态大小的父元素中元素的滚动范围?
    在交互式界面中实现垂直滚动元素的CSS高度限制 考虑一个布局,其中我们具有与可滚动的映射div一起移动的subollable map div用户的垂直滚动,同时保持其与固定侧边栏的对齐方式。但是,地图的滚动无限期扩展,超过了视口的高度,阻止用户访问页面页脚。 可以限制地图的滚动,我们可以利用CSS...
    编程 发布于2025-02-06
  • 如何将命令行卷曲转换为PHP卷曲?
    如何将命令行卷曲转换为PHP卷曲?
    [2排在PHP脚本。本文提供了一个详细的解决方案,用于将特定的curl命令转换为php。 php curl translation: 在php中复制此命令,您可以按照以下步骤进行以下步骤: URL和文件名的动态零件的变量:构造完整的url:初始化curl请求: //设置cookie(如果可用) cu...
    编程 发布于2025-02-06
  • 如何在Java字符串中有效替换多个子字符串?
    如何在Java字符串中有效替换多个子字符串?
    利用正则表达式示例示例usage 接下来,您可以使用匹配器查找令牌的所有出现,并用相应的值替换它们: 一旦汇总正则表达式,搜索输入字符串通常非常快, 。此外,正则表达式还可以灵活地处理复杂的搜索模式,例如涉及括号和量词的模式。
    编程 发布于2025-02-06
  • 如何在Java列表中有效计算元素的发生?
    如何在Java列表中有效计算元素的发生?
    计数列表中的元素出现在列表 中,在java编程中,列举列表中列举元素出现的任务来自列表。为此,收集框架提供了全面的工具套件。在这种情况下,Batocurrences变量将保持值3,代表动物列表中的“ BAT”出现的数量。 &&& [此方法是简单的,可以得出准确的结果,使其成为计算列表中元素出现的理...
    编程 发布于2025-02-06
  • PHP阵列键值异常:了解07和08的好奇情况
    PHP阵列键值异常:了解07和08的好奇情况
    PHP数组键值问题,使用07&08 在给定数月的数组中,键值07和08呈现令人困惑的行为时,就会出现一个不寻常的问题。运行print_r($月份)返回意外结果:键“ 07”丢失,而键“ 08”分配给了9月的值。此问题源于PHP对领先零的解释。当一个数字带有0(例如07或08)的前缀时,PHP将...
    编程 发布于2025-02-06
  • 如何修复\“常规错误:2006 MySQL Server在插入数据时已经消失\”?
    如何修复\“常规错误:2006 MySQL Server在插入数据时已经消失\”?
    插入记录时如何解决“一般错误:2006 MySQL 服务器已消失”介绍:将数据插入 MySQL 数据库有时会导致错误“一般错误:2006 MySQL 服务器已消失”。当与服务器的连接丢失时会出现此错误,通常是由于 MySQL 配置中的两个变量之一所致。解决方案:解决此错误的关键是调整wait_tim...
    编程 发布于2025-02-06
  • \“(1)vs.(;;):编译器优化是否消除了性能差异?\”
    \“(1)vs.(;;):编译器优化是否消除了性能差异?\”
    使用(1)而不是(;;)会导致无限循环的性能差异? 现代编译器,(1)和(;;)之间没有性能差异。 是如何实现这些循环的技术分析在编译器中: perl: S-> 7 8 unstack v-> 4 -e语法ok 在GCC中,两者都循环到相同的汇编代码中,如下所示:。 globl t_时 t_时...
    编程 发布于2025-02-06
  • 如何从Java应用程序运行批处理文件?
    如何从Java应用程序运行批处理文件?
    在Java Applications中运行批处理文件 解决方案:利用CMD 克服此挑战的关键是使用CMD命令执行批处理文件。这是校正后的Java代码: runtime.getRuntime()。exec(“ cmd /c start \'\” build.bat“); 通过添加“ c...
    编程 发布于2025-02-06
  • 如何在Bootstrap 3中冻结第一个表列以增强移动可用性?
    如何在Bootstrap 3中冻结第一个表列以增强移动可用性?
    [2表。为了使桌子在这些设备上响应迅速,Bootstrap提供了“表响应”类。但是,您可能会发现,即使用户水平滚动,通常包含表标头的第一列仍保持固定和可见。 实现此目的是通过jQuery and CSS的组合: [2 var $ table = $('。table'); ...
    编程 发布于2025-02-06
  • 为什么使用固定定位时,为什么具有100%网格板柱的网格超越身体?
    为什么使用固定定位时,为什么具有100%网格板柱的网格超越身体?
    网格超过身体,用100%grid-template-columns 问题:考虑以下CSS和HTML: position:fixed; grid-template-columns:40%60%; grid-gap:5px; 背景:#eee; 当位置未固定时,网格将正确显示。但是,当...
    编程 发布于2025-02-06
  • 如何在JavaScript对象中动态设置键?
    如何在JavaScript对象中动态设置键?
    如何为JavaScript对象变量创建动态键,尝试为JavaScript对象创建动态键,使用此Syntax jsObj['key' i] = 'example' 1;将不起作用。正确的方法采用方括号:他们维持一个长度属性,该属性反映了数字属性(索引)和一个数字属性的数量。标准对象没有模仿这...
    编程 发布于2025-02-06
  • 如何从MySQL中的文本文件执行SQL脚本?
    如何从MySQL中的文本文件执行SQL脚本?
    。 && && && && && home \ home \ sivakumar \ desktop \ test.sql错误:无法打开文件'\ home \ sivakumar \ desktop \ test.sql',错误:2 : [&& && && &&华术详细说明:[&...
    编程 发布于2025-02-06
  • 如何克服PHP的功能重新定义限制?
    如何克服PHP的功能重新定义限制?
    克服PHP的函数重新定义限制在PHP中,多次定义一个相同名称的函数是一个no-no。尝试这样做,如提供的代码段所示,将导致可怕的“不能重新列出”错误。 // error:“ coss redeclare foo()” 但是,php工具腰带中有一个隐藏的宝石:runkit扩展。它使您能够灵活地...
    编程 发布于2025-02-06
  • 如何使用替换指令在GO MOD中解析模块路径差异?
    如何使用替换指令在GO MOD中解析模块路径差异?
    克服go mod中的模块路径差异 coreos/bbolt:github.com/coreos/ [email受保护]:解析go.mod:模块将其路径声明为:go.etcd.io/bbolt `要解决此问题,您可以在go.mod文件中使用替换指令。只需在go.mod的末尾添加以下行:[&& &...
    编程 发布于2025-02-06
  • 如何实施团结延误进行游戏和事件测序?
    如何实施团结延误进行游戏和事件测序?
    Unity延迟实现详解 在Unity中创建延迟对于管理游戏流程、排序事件和模拟真实世界行为至关重要。以下是实现延迟的几种方法: 1. WaitForSeconds/WaitForSecondsRealtime StartCoroutine: 声明一个协程函数。 WaitForSeconds: ...
    编程 发布于2025-02-06

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3