OJ : 1091 : 童年生活二三事(多实例测试)

输入

输入包括多组数据。

每组数据包括一行:N(1≤N≤40)。

输入以0结束

输出

对应每个输入包括一个输出。

为redraiment到达第n阶不同走法的数量。

样例输入
复制代码
1
3
0
样例输出
复制代码
1
3

思路:

对于这个问题,我们要求解到达第n阶台阶的不同走法数量。因此,我们可以考虑从前面的台阶开始逐步推导到达第n阶的走法数量。我们可以定义一个数组 arr,其中 arr[i] 表示到达第i阶台阶的不同走法数量。对于第i阶台阶,我们可以从第i-1阶走一步到达,或者从第i-2阶蹦两步到达。因此,到达第i阶的走法数量就等于到达第i-1阶的走法数量加上到达第i-2阶的走法数量。可以结合下面的代码进行理解。

cs 复制代码
#include <stdio.h>


int main() {
    int arr[40]; // 定义数组
    arr[0] = 1; //当有0阶台阶时,我们只有一种走法,即不走
    arr[1] = 1;//当有1阶台阶时,我们只有一种走法,即走一步到达

    int n;
    while (scanf("%d", &n) && n > 0) 
    {
        for (int i = 2; i <= n; i++) //用循环来计算从2阶到n阶的走法数量
        {
            arr[i] = arr[i - 1] + arr[i - 2];//到达第i阶的走法数量就等于到达第i-1阶的走法数量加上到达第i-2阶的走法数量
        }
        printf("%d\n", arr[n]);
    }

    return 0;
}
相关推荐
宵时待雨13 小时前
回溯算法专题1:递归
数据结构·c++·笔记·算法·leetcode·深度优先
爱思德学术13 小时前
【SPIE出版】黄冈师范学院主办!第四届大数据、计算智能与应用国际会议(BDCIA 2026)
大数据·算法·数据分析·云计算·etl
洛水水13 小时前
【力扣100题】40.二叉树中的最大路径和
算法·leetcode·深度优先
洛水水13 小时前
【力扣100题】37.从前序与中序遍历序列构造二叉树
c++·算法·leetcode
zyq99101_113 小时前
递归与动态规划实战代码解析
python·算法·蓝桥杯
一只机电自动化菜鸟13 小时前
一建机电备考笔记(34)焊接技术(设备与材料1)(含考频+题型)
笔记·学习·职场和发展·生活·学习方法
橘白31614 小时前
rl笔记(一):策略梯度更新算法推导
人工智能·算法·机器人·强化学习
hhhhhaaa14 小时前
多节点矩阵式任务系统:统一配置中心与动态规则引擎架构设计
后端·算法·架构
吃着火锅x唱着歌14 小时前
LeetCode 739.每日温度
算法·leetcode·职场和发展
如竟没有火炬14 小时前
去除重复字母——贪心+单调栈
开发语言·数据结构·python·算法·leetcode·深度优先