C语言项目参考-爬楼梯

C语言教学 专栏收录该内容
62 篇文章 3 订阅

【项目-爬楼梯】
  楼梯有n阶台阶,上楼可以一步上1阶,也可以一步上2阶,编一程序计算共有多少种不同的走法?

【参考解答(递归法)】
  基础:楼梯有一个台阶,只有一种走法(一步登上去);两个台阶,有2种走法(一步上去,或分两次上去);
  递推:有n个台阶时,设有count(n)种走法,最后一步走1个台阶,有count(n-1)种走法;最后一步走2个台阶,有count(n-2)种走法。于是count(n)=count(n-1)+count(n-2)。
  可见,此问题的数学模型竟然是斐波那契数。

#include<stdio.h>
int main()
{
    unsigned long count(int n);
    int n;
    unsigned long m;
    printf("请输入楼梯的阶数:");
    scanf("%d",&n);
    m=count(n);
    printf("有%lu种爬楼梯的方法\n",m);
    return 0;
}
unsigned long count (int n)
{
    unsigned long f;
    if(n==1)
        f=1;
    else if(n==2)
        f=2;
    else
        f=count(n-1)+count(n-2);
    return(f);
}
  • 4
    点赞
  • 3
    评论
  • 9
    收藏
  • 一键三连
    一键三连
  • 扫一扫,分享海报

相关推荐
©️2020 CSDN 皮肤主题: 编程工作室 设计师:CSDN官方博客 返回首页
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值