Golang 递归函数

在Golang中,递归函数是一个直接或间接调用自身的函数。这种技术通常用于解决需要重复计算或操作一个复杂问题的子问题的问题。

以下是一些Golang中递归函数的常见应用场景和相应的代码示例:

  1. 计算阶乘:



package main
 
import "fmt"
 
func factorial(n int) int {
    if n == 0 {
        return 1
    }
    return n * factorial(n-1)
}
 
func main() {
    num := 5
    fmt.Println("Factorial of", num, "is", factorial(num))
}

在这个例子中,factorial函数计算一个整数的阶乘。如果n为0,则返回1,否则返回n乘以n-1的阶乘。

  1. 计算斐波那契数列:



package main
 
import "fmt"
 
func fibonacci(n int) int {
    if n <= 1 {
        return n
    }
    return fibonacci(n-1) + fibonacci(n-2)
}
 
func main() {
    num := 10
    fmt.Println("Fibonacci of", num, "is", fibonacci(num))
}

在这个例子中,fibonacci函数计算斐波那契数列的第n项。如果n小于或等于1,则返回n,否则返回fibonacci(n-1)fibonacci(n-2)的和。

  1. 递归遍历目录:



package main
 
import (
    "fmt"
    "io/ioutil"
    "os"
)
 
func listFiles(dir string) {
    files, err := ioutil.ReadDir(dir)
    if err != nil {
        fmt.Println(err)
        return
    }
    for _, file := range files {
        path := dir + "/" + file.Name()
        if file.IsDir() {
            fmt.Println("directory:", path)
            listFiles(path)
        } else {
            fmt.Println("file:", path)
        }
    }
}
 
func main() {
    dir, err := os.Getwd()
    if err != nil {
        fmt.Println(err)
        return
    }
    fmt.Println("Listing files in directory:", dir)
    listFiles(dir)
}

在这个例子中,listFiles函数递归遍历一个目录,打印出所有的文件和子目录。如果一个文件是目录,则继续遍历这个目录。

  1. 二分查找:



package main
 
import "fmt"
 
func binarySearch(arr []int, l int, r int, x int) int {
    if r >= l {
        mid := l + (r-l)/2
        if arr[mid] == x {
            return mid
        }
        if arr[mid] > x {
            return binarySearch(arr, l, mid-1, x)
        }
        return binarySearch(arr, mid+1, r, x)
    }
    return -1
}
 
func main() {
    arr := []int{2, 3, 4, 10, 40}
    x := 10
    fmt.Println("Element is present at index:", binarySearch(arr, 0, len(arr)-1, x))
}

在这个例子中,binarySearch函数使用递归实现了二分查找算法。如果数组中含有x,则返回x在数组中的索引,否则返回-1。

以上示例展示了Golang中递归函数的一些常见用法

最后修改于:2024年08月27日 18:43

评论已关闭

推荐阅读

DDPG 模型解析,附Pytorch完整代码
2024年11月24日
DQN 模型解析,附Pytorch完整代码
2024年11月24日
AIGC实战——Transformer模型
2024年12月01日
Socket TCP 和 UDP 编程基础(Python)
2024年11月30日
python , tcp , udp
如何使用 ChatGPT 进行学术润色?你需要这些指令
2024年12月01日
AI
最新 Python 调用 OpenAi 详细教程实现问答、图像合成、图像理解、语音合成、语音识别(详细教程)
2024年11月24日
ChatGPT 和 DALL·E 2 配合生成故事绘本
2024年12月01日
omegaconf,一个超强的 Python 库!
2024年11月24日
【视觉AIGC识别】误差特征、人脸伪造检测、其他类型假图检测
2024年12月01日
[超级详细]如何在深度学习训练模型过程中使用 GPU 加速
2024年11月29日
Python 物理引擎pymunk最完整教程
2024年11月27日
MediaPipe 人体姿态与手指关键点检测教程
2024年11月27日
深入了解 Taipy:Python 打造 Web 应用的全面教程
2024年11月26日
基于Transformer的时间序列预测模型
2024年11月25日
Python在金融大数据分析中的AI应用(股价分析、量化交易)实战
2024年11月25日
AIGC Gradio系列学习教程之Components
2024年12月01日
Python3 `asyncio` — 异步 I/O,事件循环和并发工具
2024年11月30日
llama-factory SFT系列教程:大模型在自定义数据集 LoRA 训练与部署
2024年12月01日
Python 多线程和多进程用法
2024年11月24日
Python socket详解,全网最全教程
2024年11月27日