码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • C语言经典题目之青蛙跳台阶问题


    目录

    一、问题描述

    二、问题分析

    1.当n=1时

    2.当n=2时

    3.当n=3时

     4.n=4,n=5........n=n时

    三、代码实现

    总结


    一、问题描述

    一只青蛙一次可以跳上 1 级台阶,也可以跳上2 级。求该青蛙跳上一个n 级的台阶总共有多少种跳法。

    二、问题分析

    青蛙跳台阶,相信大家一开始看到这道题也是没有一点思路,但是不要担心,相信自己一定能解决这道经典题目的。

    这道题我们无法直接肉眼观察出一些规律,但是我们有数学归纳法,直接看不出来,我们先写三项,三项看不出来,我们写五项,写的多了总会看出来的。

    1.当n=1时

    显然只有1级台阶,那么肯定只有一种跳法了。

    2.当n=2时

    这个时候我们有两种跳法,一种是直接跳两级,另外一种是先跳一级,再跳一级。

    3.当n=3时

    这个时候我们的选择可就多了,单纯的打字打出来并不是一种明智的选择,我们画一个图试试看

     青蛙第一次可以选择跳一层,也可以第一次跳两层,为了方便起见,不妨我们定义青蛙跳n层台阶共有f(n)种跳法

    那么f(3)就有如下图所示,第一次跳1或者2,如果是1,则第二次继续跳1,或者2,如果第一次是2,那么直接跳1即可

     4.n=4,n=5........n=n时

    其实在这块已经有人能看到规律了,因为第一步无非就两种跳法,要么跳1,要么跳2。如果假设n个台阶有f(n)种跳法。那么则第二步有f(n-1)和f(n-2)种跳法。然后我们就发现,这不就是斐波那契数列吗。只不过就是把第二项变为2了。其余一个都没变

    事实上,确实是这样的,这道题规律是比汉诺塔要好找很多的。

    三、代码实现

    既然本质上上就是一个斐波那契数列求第n项,只不过是第二项变为2了这种情况。那么问题迎刃而解,斐波那契数列在之前的文章中花费了大量的篇幅去详细讲解,这里给出传送门:http://t.csdn.cn/Khk31

    我们直接实现代码吧

    1. #include<stdio.h>
    2. int f(int n)
    3. {
    4. if (n == 1)
    5. {
    6. return 1;
    7. }
    8. else if (n == 2)
    9. {
    10. return 2;
    11. }
    12. else
    13. {
    14. return f(n - 1) + f(n - 2);
    15. }
    16. }
    17. int main()
    18. {
    19. int n;
    20. scanf("%d", &n);
    21. int ret = f(n);
    22. printf("%d", ret);
    23. return 0;
    24. }

    总结

    好了本期内容就讲解这么多,青蛙跳台阶和汉诺塔问题有点类似,都是需要透过现象看本质。寻找规律,从而一举制胜。

  • 相关阅读:
    vue的生命周期
    游戏遇到的问题
    SpringClouldAlibaba 之 Sentinel流控规则同步到nacos(并重新生成镜像)
    Redis配置与优化
    1.数据结构与算法 基础知识
    解救Kubernetes混乱:Descheduler快速实现资源平衡
    Keras中reset_states对stateful的影响探究
    瀑布流布局2
    多目标粒子群优化算法 (MOPSO)(Matlab代码实现)
    C#:实现SHA1加密算法(附完整源码)
  • 原文地址:https://blog.csdn.net/jhdhdhehej/article/details/127758614
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号