golang实现斐波那契

该博客展示了两种不同的斐波那契数列计算方法:一种使用递归函数,另一种利用切片存储。递归方法直接计算每个数,而切片方法则构建了一个数组,存储了指定数量的斐波那契数。这两种方法分别适用于不同的场景,递归适合小规模计算,切片适合需要整个序列的情况。
摘要由CSDN通过智能技术生成
package main

import "fmt"

func fibonacci(n int) int { //定义函数,参数是n int类型,输出int类型,返回值是参数的前两个之和
	if n < 2 {
		return n
	}
	return fibonacci(n-2) + fibonacci(n-1)

}
func main() {
	var i int //定义变量i
	for i = 0; i < 20; i++ {
		fmt.Printf("%d\t", fibonacci(i))
	} //i自增传递给函数
}
package main

import "fmt"

func fibonacci(n int) []int { //定义函数 参数 n int类型,输出时切片,返回值是一个人条件判断
	if n < 2 {
		return make([]int, 0) //返回一个切片
	}
	nums := make([]int, n)  //nums切片,长度是n
	nums[0], nums[1] = 1, 1 //前片的0。1赋值
	for i := 2; i < n; i++ {
		nums[i] = nums[i-1] + nums[i-2]
	}
	return nums //i等于前两个之和
}
func main() {
	var num int
	fmt.Println("要多大的斐波那契额")
	fmt.Scanln(&num)
	fmt.Println(fibonacci(num))
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值