【算法】【递归与动态规划模块】跳跃游戏
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
再次感谢左大神对我算法的指点迷津!

相关内容

热门资讯

原创 4... 写在文章前的声明:在本文之前的说明:本文中所列的投资信息,只是一个对基金资产净值进行排行的客观描述,...
胜宏科技港股大涨49% 做完英... 记者 陈月芹 4月21日,全球AI算力板龙头胜宏科技(02476.HK)登陆港交所,上市首日股价大涨...
永赢基金:聚焦“科技新锐”,科... 数据来源:Wind,时间统计区间为2025/1/1-2026/4/21,指数过往表现不预示未来,不构...
五大阅读趋势显现!当当网发布2... 在第31个世界读书日即将来临之际及首个全民阅读活动周期间,当当网正式发布2026国民阅读洞察报告。 ...
业绩逐季回暖 老百姓大药房一季... 上证报中国证券网讯(记者 夏子航)4月22日晚,老百姓大药房发布2025年年报和2026年一季报。今...
中国20强城市大洗牌:苏州接近... 中国的城市经济竞争格局一直在变化,每年发布的GDP数据都会对城市经济实力进行重新排列。2025年榜又...
直击金宏气体股东会:预期年内氦... 《科创板日报》4月22日讯(记者 郭辉)金宏气体日前举行2025年度股东大会。会上该公司审议了公司年...
5月1日起,俄据悉将叫停哈萨克... 据行业消息人士透露,俄罗斯将于5月1日起停止经友谊管道转运哈萨克斯坦输往德国的石油,相关调整计划已送...
深化具身智能生态布局 京东携手... 4 月 22 日,京东与国内消费级人形机器人头部企业松延动力正式达成三年期战略合作。双方将围绕产品研...
原创 帮... 先问你一个问题,美伊停火今晚到期,按常理避险情绪该升温,黄金应该涨吧?结果恰恰相反——原油涨了,黄金...
300295、600889,将... 三六五网、南京化纤,将被*ST。 公司股票自4月23日开市起停牌一天,于4月24日开市起复牌并实施退...
能源大变天!外媒:羡慕中国的石... 这一次油价突破 110 美元的能源危机,着实魔幻。如果放在十年前,没人会相信中国能在这场风波中获利,...
黄金涨跌两难,现在还能上车吗? 中新网4月22日电(记者 左雨晴) 四月以来,美伊局势反复拉扯,美联储降息预期一变再变。黄金价格在4...
“我身体健康”,库克现身员工大... 当地时间4月21日,受苹果官宣CEO换届影响,公司股价盘中下探超2%,总市值失守4万亿美元关口,收盘...
库克留下一个悬念 工程师能否拯救创新节奏? 听筒Tech(ID:tingtongtech)原创 文 | 赵 森 ...
探索消费信贷与社交支付深度融合... 腾讯这一金融产品再添新功能,4月19日,北京商报记者注意到,微信分付灰度测试转账功能引发热议,在向微...
土耳其主要银行股指早盘下跌2% 每经AI快讯,4月20日,土耳其主要银行股指早盘下跌2%。 每日经济新闻
好用的OTA代运营源头厂家 在如今竞争激烈的酒旅行业中,OTA代运营服务成为了众多酒店、民宿提升竞争力的关键。但市场上的代运营厂...
成都五一出游全国热门第三 “五一”假期临近,同程旅行最新发布的《2026“五一”旅行趋势报告》显示,今年“五一”期间成都同时位...