Golang反转链表

ES_KYW · · 1382 次点击 · · 开始浏览    
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

反转链表

func revoert_linklist(pHead *ListNode) *ListNode {
    var newHead,temp *ListNode
    for pHead != nil  {
        // 赋值头head到临时节点
        temp  = pHead
        // pHead移到了下一位
        pHead = pHead.Next
        // 对新链表做头插
        temp.Next = newHead
        // newHead前移动,准备下一次循环
        newHead = temp
    }
    return newHead
}
测试
link1 := &ListNode{}
    link1.Val = 1
    link2 := &ListNode{}
    link2.Val = 2
    link3 := &ListNode{}
    link3.Val = 3
    link4 := &ListNode{}
    link4.Val = 4
    link5 := &ListNode{}
    link5.Val = 5

    link1.Next = link2
    link2.Next = link3
    link3.Next = link4
    link4.Next = link5

    fmt.Println(link1)
    pre :=revoert_linklist(link1)
    fmt.Println(pre.Val)
    fmt.Println(pre.Next.Val)
    fmt.Println(pre.Next.Next.Val)
    return
&{1 0xc42016c600}
5
4
3


有疑问加站长微信联系(非本文作者)

本文来自:简书

感谢作者:ES_KYW

查看原文:Golang反转链表

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

1382 次点击  
加入收藏 微博
暂无回复
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传