【Go】走台阶

问题:有N个台阶,每次可以走一个台阶也可以走两个台阶,请问有多少种走法?

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
package main
 
import "fmt"
 
func step(n uint) uint {
   if n < 1 {
      return 0
   } else if n == 1 {
      return 1
   } else if n == 2 {
      return 2
   } else {
      // 1. 先走1步,则剩下n-1个台阶,那么问题变为走完n-1个台阶有多少种走法。
      // 2. 先走2步,则剩下n-2个台阶,那么问题变为走完n-2个台阶有多少种走法。
      // 3. 上面两种情况相加,就是走完n个台阶的走法。
      return step(n-1) + step(n-2)
   }
}
 
func main() {
   fmt.Println(step(5))
}

  

posted @   kunsile  阅读(48)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
点击右上角即可分享
微信分享提示