Go语言每日一练链表篇(一)

简介: Go语言每日一练链表篇(一)

题目传送门

牛客面试必刷101题 ----------反转链表

题目以及答案源码

反转链表

题目

解题方法

  1. 递归函数遍历链表并反转
package main
import _"fmt"
import . "nc_tools"
/*
 * type ListNode struct{
 *   Val int
 *   Next *ListNode
 * }
 */
/**
 * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
 *
 * 
 * @param head ListNode类 
 * @return ListNode类
*/
func ReverseList( head *ListNode ) *ListNode {
    if head==nil{
        return head
    }
    if head.Next==nil{
        return head
    }
    root:=ReverseList(head.Next)
    head.Next.Next=head
    head.Next=nil
    return root
}

2.三指针迭代法

package main
import _"fmt"
import . "nc_tools"
/*
 * type ListNode struct{
 *   Val int
 *   Next *ListNode
 * }
 */
/**
 * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
 *
 * 
 * @param head ListNode类 
 * @return ListNode类
*/
func ReverseList( head *ListNode ) *ListNode {
    if head ==nil|| head.Next==nil{
        return head
    }
    var prev *ListNode=nil
    current:=head
    for current!=nil{
        next:=current.Next
        current.Next=prev
        prev=current
        current=next
    }
    return prev
}


相关文章
|
9天前
|
Shell Go API
Go语言grequests库并发请求的实战案例
Go语言grequests库并发请求的实战案例
|
1天前
|
安全 Go 数据处理
探索Go语言的并发之美:Goroutines与Channels
在Go语言的世界里,"并发"不仅仅是一个概念,它是一种生活的方式。本文将带你领略Go语言中Goroutines和Channels的魔力,它们是如何让并发编程变得既简单又高效。我们将通过一个简单的示例,展示如何使用这些工具来构建一个高性能的网络服务。
|
1天前
|
关系型数据库 Go 数据处理
高效数据迁移:使用Go语言优化ETL流程
在本文中,我们将探索Go语言在处理大规模数据迁移任务中的独特优势,以及如何通过Go语言的并发特性来优化数据提取、转换和加载(ETL)流程。不同于其他摘要,本文不仅展示了Go语言在ETL过程中的应用,还提供了实用的代码示例和性能对比分析。
|
2天前
|
Go 定位技术 索引
Go 语言Map(集合) | 19
Go 语言Map(集合) | 19
|
2天前
|
Go
go语言注释,标识符 | 17
go语言注释,标识符 | 17
|
1天前
|
NoSQL Go API
go语言操作Redis
go语言操作Redis
|
1天前
|
Unix Go
go语言获取当前时间戳
go语言获取当前时间戳
|
1天前
|
Go
go语言李mapstructure啥意思
go语言李mapstructure啥意思
|
3天前
|
存储 缓存 Go
go语言编程系列(五)
go语言编程系列(五)
|
3天前
|
搜索推荐 Java 编译器
go语言编程系列(四)
go语言编程系列(四)