学无止境_--_ 2022-12-29 19:29 采纳率: 60%
浏览 91
已结题

一只小蜜蜂在如下图所示的蜂窝上爬行。它爬行时,只能从一个格爬到相邻的大号格子中。例如,从 1 号格子可以爬到 2 号或者 3 号格子,从 2 号则可以爬到 3 号或者 4 号格子。

一只小蜜蜂在如下图所示的蜂窝上爬行。它爬行时,只能从一个格爬到相邻的大号格子中。例如,从 1 号格子可以爬到 2 号或者 3 号格子,从 2 号则可以爬到 3 号或者 4 号格子。

img


请问从一个格子 a 爬到一个格子 b 一共有多少种可行的路线。
输入:
分别是起始点 a 和终止点 b 的编号。( a 和 b 在 1~100 之间,且 a<b 。)
输出:
方案数量。
这个代码为什么在1 100的输入下得到了错误的输出

#include <stdio.h>
int main()
{
    long long  arr[101] = {0};
    arr[2] = 1;
    arr[3] = 2;
    for (int i = 4; i < 101; i++)
    {
        arr[i] = arr[i - 1] + arr[i - 2];
    }
    int start = 0, end = 0;
    scanf("%d %d", &start, &end);
    printf("%lld\n", arr[end - start + 1]);
    return 0;
}
  • 写回答

1条回答 默认 最新

  • ShowMeAI 2022-12-29 20:22
    关注

    在算法中,求解 a 到 b 的方案数量时,使用了 arr[end - start + 1] 这个表达式,而实际上应该使用 arr[end - start]。

    修改后的代码如下:

    #include <stdio.h>
    int main()
    {
    long long arr[101] = {0};
    arr[2] = 1;
    arr[3] = 2;
    for (int i = 4; i < 101; i++)
    {
    arr[i] = arr[i - 1] + arr[i - 2];
    }
    int start = 0, end = 0;
    scanf("%d %d", &start, &end);
    printf("%lld\n", arr[end - start]);
    return 0;
    }
    
    评论

报告相同问题?

问题事件

  • 已结题 (查看结题原因) 1月5日
  • 创建了问题 12月29日

悬赏问题

  • ¥15 深度学习根据CNN网络模型,搭建BP模型并训练MNIST数据集
  • ¥15 lammps拉伸应力应变曲线分析
  • ¥15 C++ 头文件/宏冲突问题解决
  • ¥15 用comsol模拟大气湍流通过底部加热(温度不同)的腔体
  • ¥50 安卓adb backup备份子用户应用数据失败
  • ¥20 有人能用聚类分析帮我分析一下文本内容嘛
  • ¥15 请问Lammps做复合材料拉伸模拟,应力应变曲线问题
  • ¥30 python代码,帮调试,帮帮忙吧
  • ¥15 #MATLAB仿真#车辆换道路径规划
  • ¥15 java 操作 elasticsearch 8.1 实现 索引的重建