当前位置: 首页 > news >正文

Java 华为真题-猴子爬山

需求:

  一天一只顽猴想去从山脚爬到山顶,途中经过一个有个N个台阶的阶梯,但是这猴子有一个习惯:每一次只能跳1步或跳3步,试问猴子通过这个阶梯有多少种不同的跳跃方式?

输入描述

        输入只有一个整数N(0<N<=50)此阶梯有多少个台阶。

输出描述

        输出有多少种跳跃方式(解决方案数)。

 

输入

3

输出

2

 

输入

50

输出

122106097

分析:

上山最后一步到达第50级台阶,完成上山,共有f(50)种不同的爬法,

到第50级之前位于哪一级呢?无非是位于第49级(上跳1级即到),有f(49)种;

或位于第48级(上跳3级即到),有f(48)种,于是:

f(50)=f(49)+f(47)
f(49)= f(48)+f(46)
f(48)= f(47)+f(45)
依次类推
以此类推,一般地有递推关系:

f(n)=f(n-1)+f(n-3) (n>3)
初始条件:

f(1)=1,即1=1;

f(2)=1,即2=1+1(注意:跳法中不允许直接跳2级);

f(3)=2,即3=1+1+1,3=3;

故此递推设计比较简单,时间复杂度为O(n)

编码:

public class TestDump {public static void main(String[] args) {Scanner scanner=new Scanner(System.in);System.out.print("请输入阶梯数:");int num=scanner.nextInt();System.out.println(showF(num));}/*** 递归算法f(n) = f(n-1) + f(n-3);* f(1) =1;f(2) =1;f(3) = 2*/public static long showF(int n) {if (n == 1 || n == 2) {return 1;}if (n == 3) {return 2;}return showF(n - 1) + showF(n - 3);}
}

效果:

http://www.lryc.cn/news/170930.html

相关文章:

  • Axios笔记
  • 如何使用try-except语句处理Python中的异常
  • 学Python的漫画漫步进阶 -- 第十一步.常用的内置模块
  • 发现无尽的创意可能性——Photo Image Editor Pixelstyle for Mac
  • Smart Community(1)之设计规范
  • 爬虫工作者必备:使用爬虫IP轻松获得最强辅助
  • 工作比读研简单多了
  • 【音视频】H264视频压缩格式
  • Windows【工具 04】WinSW官网使用说明及实例分享(将exe和jar注册成服务)实现服务器重启后的服务自动重启
  • 【C++面向对象侯捷】3.构造函数
  • GE WESDAC D20ME 模拟输入电子模块
  • GE WES5302-150 数字量控制模块
  • Redis-渐进式遍历scan的使用
  • 数据结构——查找
  • 设计模式六大原则
  • Docker 安装
  • 国外发达国家码农是真混得好么?
  • 构造函数不能做为虚函数
  • 持续集成实战 —— Jenkins自动化测试环境搭建
  • ajax上传文件
  • 使用jib-maven-plugin插件构建镜像并推送至私服Harbor
  • 道路空间功率谱密度与时间功率谱密度(笔记)
  • JMeter接口测试之文件上传
  • 自动化测试需知的4项测试工具!
  • 【深度学习】clip-interrogator clip docker 容器启动过程
  • Linux设备驱动之gpio-keys
  • 【vue3页面展示代码】展示代码codemirror插件
  • 【面试必刷TOP101】链表相加 单链表的排序
  • Visual Studio复制、拷贝C++项目与第三方库配置信息到新的项目中
  • rust迭代器