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

【牛客面试必刷TOP101】Day11.BM63 跳台阶和 BM67 不同路径的数目(一)

作者简介:大家好,我是未央;

博客首页:未央.303

系列专栏:牛客面试必刷TOP101

每日一句:人的一生,可以有所作为的时机只有一次,那就是现在!!!!!

文章目录

前言

一、跳台阶

题目描述

题目解析

二、不同路径的数目(一)

题目描述

题目解析

总结



前言

一、跳台阶

题目描述

描述:
一只青蛙一次可以跳上1级台阶,也可以跳上2级。求该青蛙跳上一个 n 级的台阶总共有多少种跳法(先后次序不同算不同的结果)。


数据范围:1≤n≤40

要求:时间复杂度:O(n) ,空间复杂度: O(1)。


示例1:


示例2:


题目解析

解题思路:

假设f[i]表示在第i个台阶上可能的方法数。逆向思维。如果我从第n个台阶进行下台阶,下一步有2中可能,一种走到第n-1个台阶,一种是走到第n-2个台阶。

所以f[n] = f[n-1] + f[n-2]. 那么初始条件了,f[0] = f[1] = 1。

所以就变成了:f[n] = f[n-1] + f[n-2], 初始值f[0]=1, f[1]=1,目标求f[n] 。


和斐波那契数列的模式一样。


代码解析:



二、不同路径的数目(一)

题目描述

描述:

一个机器人在m×n大小的地图的左上角(起点)。

机器人每次可以向下或向右移动。机器人要到达地图的右下角(终点)。

可以有多少种不同的路径从起点走到终点?

备注:m和n小于等于100,并保证计算结果在int范围内;


数据范围:0<n,m≤100,保证计算结果在32位整型范围内

要求:空间复杂度 O(nm),时间复杂度 O(nm)

进阶:空间复杂度 O(1),时间复杂度O(min(n,m))


示例1:


示例2:


题目解析

解题思路:

首先我们在左上角第一个格子的时候,有两种行走方式:如果向右走,相当于后面在一个(n−1)∗m的矩阵中查找从左上角到右下角的不同路径数;而如果向下走,相当于后面在一个n∗(m−1)的矩阵中查找从左上角到右下角不同的路径数。

而(n−1)∗m的矩阵与n∗(m−1)的矩阵都是n∗m矩阵的子问题,因此可以使用递归。


解题步骤:

  • step 1:(终止条件) 当矩阵边长n减少到1的时候,很明显只能往下走,没有别的选择了,只有1条路径;同理m减少到1时也是如此。因此此时返回数量为1.
  • step 2:(返回值) 对于每一级都将其两个子问题返回的结果相加返回给上一级。
  • step 3:(本级任务) 每一级都有向下或者向右两种路径选择,分别进入相应分支的子问题。

代码解析:

总结

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

相关文章:

  • [NOIP 2022] 建造军营 题解
  • 射频识别技术(RFID)在智能制造模具管理中的应用
  • 奖品定制经营商城小程序的作用是什么
  • 深度学习常用脚本总结
  • hive数据表创建
  • 查看本机Arp缓存,以及清除arp缓存
  • Unity MRTK Hololens2眼动交互
  • 接口自动化测试 —— 协议、请求流程
  • JDK安装详细教程
  • vulnhub_Fowsniff靶机渗透测试
  • FPGA面试题(3)
  • Avalonia常用小控件Menu
  • steam游戏服务器如何选择
  • 电脑技巧:推荐一款桌面整理神器TidyTabs
  • git合并分支-IDEA
  • winscope使用方法
  • 获取西华大学新闻网站信息(爬虫样例)
  • 【Linux】https协议
  • 基于工业5G网关的工业机器人监测控制方案
  • [Machine learning][Part4] 线性回归模型技巧
  • 产品经理进阶:如何写商业计划书?
  • Excel 规范录入数据
  • 使用IDEA自带功能将WSDL转java
  • Vue + moment 实现自定义日历
  • 【斗罗2】天梦哥抓捕冰帝,霍雨浩与她完美融合,喜提五挂
  • 上个月Balada Injector攻击中有超过17,000个WordPress网站被黑
  • python写一个文本处理器
  • unity发布微信小游戏,未找到 game.json报错原因
  • mysql进程信息出现大量Waiting for table level lock信息的原因,怎么处理?
  • Ubuntu不显示共享文件夹解决方案