### 斐波那契數列
> **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
- 多線程:通道思路
- 多線程爬蟲:快代理