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;
}
相关推荐
stolentime18 小时前
通信题:洛谷P15942 [JOI Final 2026] 赌场 / Casino题解
c++·算法·洛谷·joi·通信题
初生牛犊不怕苦18 小时前
与AI一起学习《C专家编程》:数组与指针
c语言·学习·算法
Kk.080219 小时前
数据结构|排序算法(二) 冒泡排序
数据结构·算法·排序算法
沛沛rh4519 小时前
深入并发编程:从 C++ 到 Rust 的学习笔记
c++·笔记·学习·算法·rust
Kk.080219 小时前
数据结构|排序算法(二) 希尔排序
数据结构·算法·排序算法
AI医影跨模态组学19 小时前
NPJ Precis Oncol(IF=8)复旦大学肿瘤医院等团队:基于生境CT放射组学解析可切除非小细胞肺癌时空异质性预测新辅助化疗免疫治疗病理反应
大数据·人工智能·算法·医学·医学影像
Book思议-20 小时前
二叉树的递归遍历详解:前序、中序与后序
数据结构·算法·二叉树的递归遍历-前中后序
Demon--hx20 小时前
[LeetCode]100 链表-专题
算法·leetcode·链表
Omics Pro20 小时前
首款多模态生物推理大语言模型
人工智能·算法·语言模型·自然语言处理·数据挖掘·数据分析·aigc