### 斐波那契数列
> **1,1,2,3,5,8,13,21,34..............这个数列从第三项开始,每一项都等于前两项的和**
使用for循环实现
```
package main
import "fmt"
func fibonacci(n int) (res int) {
a := 1
b := 1
for i := 2; i < n; i++ {
c := b
b = a + b
a = c
}
return b
}
func main() {
n := 9
fmt.Printf("斐波那契数列第%d项的值为%d", n, fibonacci(n))
// 斐波那契数列第9项的值为34
}
```
使用递归方法
```
package main
import "fmt"
func fibonacci(n int) (res int) {
if n == 1 || n == 2 {
return 1
} else {
return fibonacci(n-2) + fibonacci(n-1)
}
}
func main() {
n := 4
fmt.Printf("斐波那契数列第%d项的值为%d", n, fibonacci(n))
// 斐波那契数列第4项的值为3
}
```
使用 switch方法,其实也是递归的方法
```
package main
import "fmt"
func fibonacci(n int) (res int) {
switch n {
case 1:
return 1
case 2:
return 1
default:
return fibonacci(n-2) + fibonacci(n-1)
}
}
func main() {
n := 4
fmt.Printf("斐波那契数列第%d项的值为%d", n, fibonacci(n))
// 斐波那契数列第5项的值为8
}
```
- 安装开发环境
- 安装开发环境
- 安装详细教程
- 引入包
- Go语言基础
- 基本变量与数据类型
- 变量
- 数据类型
- 指针
- 字符串
- 代码总结
- 常量与运算符
- 常量
- 运算符
- 流程控制
- if判断
- for循环
- switch分支
- goto跳转
- 斐波那契数列
- Go语言内置容器
- 数组
- 切片
- 映射
- 函数
- 函数(上)
- 函数(中)
- 函数(下)
- 小节
- 包管理
- 结构体
- 结构体(上)
- 结构体(中)
- 结构体(下)
- 小节
- 错误处理
- 错误处理
- 宕机
- 错误应用
- 小节
- 文件操作
- 获取目录
- 创建和删除目录
- 文件基本操作(上)
- 文件基本操作(中)
- 文件基本操作(下)
- 处理JSON文件
- 接口与类型
- 接口的创建与实现
- 接口赋值
- 接口嵌入
- 空接口
- 类型断言(1)
- 类型断言(2)
- 小节
- 并发与通道
- goroutine协程
- runtime包
- 通道channel
- 单向通道channel
- select
- 线程同步
- 多线程的深入学习
- http编程
- http简介
- Client和Request
- get请求
- post请求
- 模块函数方法
- 模块
- fmt库,模块
- 项目练习
- 爬虫:高三网
- 爬虫:快代理
- 爬虫:快代理2
- 多线程:通道思路
- 多线程爬虫:快代理