golang实现斐波那契

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、付费专栏及课程。

余额充值