【算法】【递归与动态规划模块】跳跃游戏
admin
2024-01-29 04:36:08
0

目录

  • 前言
  • 问题介绍
  • 解决方案
  • 代码编写
    • java语言版本
    • c语言版本
    • c++语言版本
  • 思考感悟
  • 写在最后

前言

当前所有算法都使用测试用例运行过,但是不保证100%的测试用例,如果存在问题务必联系批评指正~

在此感谢左大神让我对算法有了新的感悟认识!

问题介绍

原问题
给定数组arr,arr[i] 为k ,代表当前位置能够往前面跳跃1~k个单位,求到达arr尾部的最少步数。
如:
[3,2,3,1,1,4]
最少步数:从arr[0] 跳跃到arr[2]从arr[2]跳跃到中点一共两步。结果为2

解决方案

原问题
递归方法:
常规递归方法即可解答,定义递归函数f(arr, i) 表示从arr[i]出发到达arr终点的最少步数.
每一个状态遍历即可。
动态规划方法:
将常规递归方法转成动态规划即可,构建一维数组dp,dp[i]表示从arr[i] 到达终点所需最少步数.
最优解:
设计三个变量jump、cur、next。jump表示 到达当前位置已经跳了多少步了,cur表示当前位置只能跳一步的话能跳的最远距离、next表示当前位置跳两步的话最远能够跳多远。
对于每一个arr[i] 计算cur是否能够到达i,如果能到达,则不需要增加步数,查看到达的地方是否能够更新next。如果不能到达,则需要增加步数,cur变成next,next持续更新。详情见代码,原理见思考。

代码编写

java语言版本

原问题:
经典递归版本:

     /*** 二轮测试:递归方法* @return*/public static int jumpCp1(int[] arr) {if (arr == null || arr.length == 0) {return 0;}return processCp1(arr, 0);}private static int processCp1(int[] arr, int i) {// -1表示跳不过去int res = Integer.MAX_VALUE;if (i >= arr.length) {// 超出去了,无法达到,直接返回最大值return Integer.MAX_VALUE;}if (i == arr.length-1) {// 已经到了,返回0步即可return 0;}int step = arr[i];for (int j = 1; j <= step; j++) {res = Math.min(res, processCp1(arr, i+j));}return res == Integer.MAX_VALUE ? -1 : res + 1;}

经典动态规划版本:

    /*** 二轮测试:动态规划* @return*/public static int dpCp1(int[] arr) {if (arr == null || arr.length == 0) {return 0;}int[] dp = new int[arr.length];dp[arr.length-1] = 0;for (int i = arr.length-2; i >= 0; i--) {int step = arr[i];int min = Integer.MAX_VALUE;for (int j = 1; j <= step; j++) {min = Math.min(min, dp[i+j]);}dp[i] = min + 1;}return dp[0];}

最优解:

    /*** 最优解* 时间 o(n) 空间 O(1)* @param arr* @return*/public static int superCp1(int[] arr) {if (arr == null || arr.length == 0) {return 0;}int jump = 0;// 当前所在位置能够跳的最远距离int cur = 0;// 下一跳的位置的最大范围int next = 0;for (int i = 0; i < arr.length; i++) {if (cur < i) {// 说明当前位置到不了了jump ++;// 跳到下一跳cur = next;}next = Math.max(next, i + arr[i]);}return jump;}

c语言版本

正在学习中

c++语言版本

正在学习中

思考感悟

这道题是一道单路线型的递归,并且很容易想到,这里就不解释了,主要思考一下最优解的优化点在什么地方
首先最优解的空间复杂度O(1),时间O(N), 递归和动态规划都没有达到这个复杂度。

首先有一个重要的指标就是,当cur小于i的时候需要跳跃了,这个时候跳跃数+1,cur=next,这里next已经遍历出了cur到i之间每一个位置能够到达的最远距离,所以这里cur跳到的位置就是能够跳到最远距离的那个位置,但是我们不关心,我们只关心下一跳能够跳到的最远距离,所以i只会递增,此时cur和i之间的位置不需要再遍历了,因为cur和i之间的距离没有一个能够跳的不cur更远的,但是递归就会暴力的尝试每一种情况导致了时间复杂度增加了一个维度。
这两种解法之间的不同在于角度,递归关心的是步数,而最优解将眼光投到了每一步中能够跳的最远位置。

写在最后

方案和代码仅提供学习和思考使用,切勿随意滥用!如有错误和不合理的地方,务必批评指正~
如果需要git源码可邮件给2260755767@qq.com
再次感谢左大神对我算法的指点迷津!

相关内容

热门资讯

装载8000万桶原油的超级油轮... 6月19日,财闻海外资讯消息,载有近8000万桶石油的超级油轮正停泊在波斯湾,一旦交易商和船东发出指...
原创 刚... 法国总统马克龙最近的状态,用一句哭笑不得来形容再贴切不过。原本他一门心思准备在对华贸易议题上做文章,...
惠誉:将宁德时代的发行人主体评... 6月18日,惠誉国际评级有限公司(下称“惠誉”)上调宁德时代(300750.SZ/03750.HK)...
临商银行“临商红”青年志愿服务... 为大力弘扬践行沂蒙精神,临商银行联合市委金融工委、市委市直机关工委、共青团临沂市委共同打造了“临商红...
SpaceX 上市:SPCX ... EBC Financial Group 自开盘起即向全球交易者提供双向交易通道,参与这一史上最大规模...
甘肃电气集团长开公司荣获202... 近日,在2026年度中国中压电器行业权威评选活动中,甘肃电气集团长开公司荣获中国中压电器市场“卓越贡...
是80%的工位面向海景,马岩松... 腾讯总部园区 摄影:张超 深圳大铲湾,腾讯总部园区“企鹅岛”于5月底首次面向公众开放。 三座由马岩松...
日本经济专家:加息难以扭转日元... 日本央行近日宣布将政策利率自0.75%上调至1.0%,为31年来最高水平。日本经济专家认为,目前日元...
黄金跌2%失守4130美元,白... 6月19日午间,黄金白银仍未止跌。截至13时,现货黄金跌2%,报4124.57美元/盎司,失守413...
原创 中... 2026年6月这个节点意味格外不同。4月伊朗与以色列那场脆弱的停火刚撑了不到两个月,6月8日两边又对...
Manus回购方案浮出水面:中... 文 | 强调Next 据外媒The Information6月18日报道,Manus的早期中国投资...
2026黄金回收避坑,郑州72... 来源:黄冈新闻网 一、郑州黄金回收市场现状与高价引流投诉占比 据郑州市 12315 消费维权平台 2...
原创 房... 2026年6月16日国家统计局公布的5月份70城房价数据显示,一线城市新建商品住宅环比上涨,二三线城...
“生活成本太高了!”全球多地年... “白天当会计,晚上跑网约车,周末送外卖,假期摆地摊……” 如今,这种“1+N”(“主业+副业”)的多...
字节之后,天数智芯的下一个客户... 今年预计交付5万片,销售部门或迎来一轮调整|图源:豆包AI 作者/ IT时报 毛宇 编辑/ 郝俊慧 ...
聚焦尾货赛道!佛山(高明)“泛... 6月18日下午,佛山(高明)“泛家居国际尾货直播基地”项目合作签约仪式在高明鸿创数字科技产业园举行。...
流量退潮,文娱市场终于“醒”了 近段时间,一场场舆论风波在文娱市场激起千层浪。老牌综艺《奔跑吧》深陷口碑泥潭,常驻嘉宾白鹿被“考古”...
原创 世... 三十年前的世界五百强榜单,中国只有3家企业上榜,隔壁日本整整149家,美国151家。那时候的世界五百...
第四套人民币小全套伍元、贰元、... 第四套人民币小全套伍元、贰元、壹圆纸币收藏鉴赏 第四套人民币是我国改革开放时代的标志性货币,承载了八...
感觉血糖还行就没事?不重视这五... 很多糖友觉得,只要平时测的血糖值看着“还行”,身体也没什么不舒服,就万事大吉了。 这是一个要命的误区...