首页后端开发其他后端知识Golang中反转一个单链表怎么做,方法是什么

Golang中反转一个单链表怎么做,方法是什么

时间2024-03-28 01:58:03发布访客分类其他后端知识浏览284
导读:关于“Golang中反转一个单链表怎么做,方法是什么”的知识点有一些人不是很理解,对此小编给大家总结了相关内容,文中的内容简单清晰,易于学习与理解,具有一定的参考学习价值,希望能对大家有所帮助,接下来就跟随小编一起学习一下“Golang中反...
关于“Golang中反转一个单链表怎么做,方法是什么”的知识点有一些人不是很理解,对此小编给大家总结了相关内容,文中的内容简单清晰,易于学习与理解,具有一定的参考学习价值,希望能对大家有所帮助,接下来就跟随小编一起学习一下“Golang中反转一个单链表怎么做,方法是什么”吧。
  

问题:反转一个单链表。

输入: 1->
    2->
    3->
    4->
    5->
    NULL
输出: 5->
    4->
    3->
    2->
    1->
NULL

首先先认识一下链表这个数据结构:

链表节点中有两个元素:

  • 指针
type ListNode struct {

    Val  int
    Next *ListNode
}
    

Next指向下一个节点

那么这道题其实就是把指针指向前一个节点

位置调换次数 pre cur whole
0 nil 1-> 2-> 3-> 4-> 5 1-> 2-> 3-> 4-> 5
1 1-> nil 2-> -3> -> 4-> 5 2-> 3-> 4-> 5-> 1-> nil
2 2-> 1-> nil 3-> 4-> 5 3-> 4-> 5-> 2-> 1-> nil
3 3-> 2-> 1-> nil 4-> 5 4-> 5-> 3-> 2-> 1-> nil
4 4-> 3-> 2-> 1-> nil 5 5-> 4-> 3-> 2-> 1-> nil

可以看出来

  • pre是cur的最前面那位(pre = cur)
  • cur就是当前位的后面链表元素(cur = cur.Next)
  • cur.Next肯定是接pre(cur.Next = pre)
完整代码:
package main

import "fmt"

//链表节点
type ListNode struct {

    Val  int
    Next *ListNode
}


//反转链表的实现
func reversrList(head *ListNode) *ListNode {

    cur := head
    var pre *ListNode = nil
    for cur != nil {

        pre, cur, cur.Next = cur, cur.Next, pre //这句话最重要
    }

    return pre
}


func main() {

    head := new(ListNode)
    head.Val = 1
    ln2 := new(ListNode)
    ln2.Val = 2
    ln3 := new(ListNode)
    ln3.Val = 3
    ln4 := new(ListNode)
    ln4.Val = 4
    ln5 := new(ListNode)
    ln5.Val = 5
    head.Next = ln2
    ln2.Next = ln3
    ln3.Next = ln4
    ln4.Next = ln5

    pre := reversrList(head)
    fmt.Println(pre)
}
    

感谢各位的阅读,以上就是“Golang中反转一个单链表怎么做,方法是什么”的内容了,通过以上内容的阐述,相信大家对Golang中反转一个单链表怎么做,方法是什么已经有了进一步的了解,如果想要了解更多相关的内容,欢迎关注网络,网络将为大家推送更多相关知识点的文章。

声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!


若转载请注明出处: Golang中反转一个单链表怎么做,方法是什么
本文地址: https://pptw.com/jishu/654624.html
canvas怎样对图片进行压缩,方法是什么 HTML5里video标签用处是什么,怎样使用

游客 回复需填写必要信息