递归DP-机器人到达目的地方法数
package com.jiucaiyuan.net.question; /** * @Author jiucaiyuan 2022/6/5 10:34 * @mail services@jiucaiyuan.net */ public class Rabbit { /** * 给了一个固定值n,表示总共有多少个位置 * 开始机器人在s位置上,每次可以迈一步,想要到达e位置,总共要走k步,有多少种走法可以到达e位置 * 机器人可以往左走,也可以往右走 * * @param n 总共位置数 1 2 3 4 ... n * @param s start开始位置(机器人开始停在s位置) * @param e end目标位置 (迈k步后,停留在e位置) * @param k 迈的步数 (机器人必须走k步) * @return 总共走法的种数 */ public static int walkWays(int n, int s, int e, int k) { return process(n, e, k, s); } /** * 暴力递归实现 * 因为递归过程类似一个二叉树的遍历,高度为k,所以时间复杂度是 O(2^k) * * @param n 总共位置1 2 3 4 5 ... n * @param e 目标位置 * @param rest 当前剩下的步数 * @param curr 当前所在的位置 * @return 当前的走法数目 */ public static int process(int n, int e, int rest, int curr) { //当前没有步骤可走了,如果在目标位置上,那么找到1中走法,如果没有在目标位置上,不是合法走法 if (rest == 0) { return curr == e ? 1 : 0; } //如果当前位置在1,那么只能往2位置走 if (rest == 1) { return process(n, e, rest - 1, 2); } //如果当前位置在n,那么下一步只能走到n-1 if (rest == n) { return process(n, e, rest - 1, n - 1); } //如果不在第一个位置,也不在最后一个位置,那么可以向左走一步,也可以往右走一步 return process(n, e, rest - 1, curr - 1) + process(n, e, rest - 1, curr + 1); } /** * 给了一个固定值n,表示总共有多少个位置 * 开始机器人在s位置上,每次可以迈一步,想要到达e位置,总共要走k步,有多少种走法可以到达e位置 * 机器人可以往左走,也可以往右走 * 优化版本,暴力递归中重复的操作用缓存空间换时间的方式优化掉 * * @param n 总共位置数 1 2 3 4 ... n * @param s start开始位置(机器人开始停在s位置) * @param e end目标位置 (迈k步后,停留在e位置) * @param k 迈的步数 (机器人必须走k步) * @return 总共走法的种数 */ public static int walkWaysV2(int n, int s, int e, int k) { int[][] dp = new int[k + 1][n + 1]; for (int i = 0; i <= k; i++) { for (int j = 0; j <= n; j++) { dp[i][j] = -1; } } return processV2(n, e, k, s, dp); } /** * 用空间换取暴力递归中重复计算的一些值 * 时间复杂度: O(k*n) * * @param n 总共位置1 2 3 4 5 ... n * @param e 目标位置 * @param rest 当前剩下的步数 * @param curr 当前所在的位置 * @param dp 计算过的值记录起来 * @return 当前的走法数目 */ public static int processV2(int n, int e, int rest, int curr, int[][] dp) { if (dp[rest][curr] != -1) { return dp[rest][curr]; } //当前没有步骤可走了,如果在目标位置上,那么找到1中走法,如果没有在目标位置上,不是合法走法 if (rest == 0) { dp[rest][curr] = curr == e ? 1 : 0; } else if (rest == 1) { //如果当前位置在1,那么只能往2位置走 dp[rest][curr] = process(n, e, rest - 1, 2); } else if (rest == n) { //如果当前位置在n,那么下一步只能走到n-1 dp[rest][curr] = process(n, e, rest - 1, n - 1); } else { //如果不在第一个位置,也不在最后一个位置,那么可以向左走一步,也可以往右走一步 dp[rest][curr] = process(n, e, rest - 1, curr - 1) + process(n, e, rest - 1, curr + 1); } return dp[rest][curr]; } /** * 动态规划方式实现 * 其实是分析上述递归过程,发现递归过程的规律,改为二维数组dp的前后联系,转化为dp二维数组的求解过程 * (动态转移方程,其实就是上述递归的过程,也是分析尝试的过程) * 时间复杂度 O(k*n) * * @param n 总共可选位置1 2 3 4 ... n * @param e 目标位置 * @param s 开始位置 * @param k 需要移动步数 * @return 返回走法数目 */ public static int dpWay(int n, int e, int s, int k) { int[][] dp = new int[k + 1][n + 1]; dp[0][e] = 1; for (int rest = 1; rest <= k; rest++) { for (int curr = 1; curr <= n; curr++) { if (curr == 1) { dp[rest][curr] = dp[rest - 1][2]; } else if (curr == n) { dp[rest][curr] = dp[rest - 1][curr - 1]; } else { dp[rest][curr] = dp[rest - 1][curr - 1] + dp[rest - 1][curr + 1]; } } } return dp[s][k]; } }
日历
个人资料

diaba 寻求合作请留言或联系mail: services@jiucaiyuan.net
链接
最新文章
存档
- 2025年4月(6)
- 2025年3月(25)
- 2025年2月(20)
- 2025年1月(2)
- 2024年10月(1)
- 2024年8月(2)
- 2024年6月(4)
- 2024年5月(1)
- 2023年7月(1)
- 2022年10月(1)
- 2022年8月(1)
- 2022年6月(11)
- 2022年5月(6)
- 2022年4月(33)
- 2022年3月(26)
- 2021年3月(1)
- 2020年9月(2)
- 2018年8月(1)
- 2018年3月(1)
- 2017年3月(3)
- 2017年2月(6)
- 2016年12月(3)
- 2016年11月(2)
- 2016年10月(1)
- 2016年9月(3)
- 2016年8月(4)
- 2016年7月(3)
- 2016年6月(4)
- 2016年5月(7)
- 2016年4月(9)
- 2016年3月(4)
- 2016年2月(5)
- 2016年1月(17)
- 2015年12月(15)
- 2015年11月(11)
- 2015年10月(6)
- 2015年9月(11)
- 2015年8月(8)
分类
热门文章
- SpringMVC:Null ModelAndView returned to DispatcherServlet with name 'applicationContext': assuming HandlerAdapter completed request handling
- Mac-删除卸载GlobalProtect
- java.lang.SecurityException: JCE cannot authenticate the provider BC
- MyBatis-Improper inline parameter map format. Should be: #{propName,attr1=val1,attr2=val2}
- Idea之支持lombok编译
标签
最新评论
- logisqykyk
Javassist分析、编辑和创建jav... - xxedgtb
Redis—常见参数配置 - 韭菜园 ... - wdgpjxydo
SpringMVC:Null Model... - rllzzwocp
Mysql存储引擎MyISAM和Inno... - dpkgmbfjh
SpringMVC:Null Model... - tzklbzpj
SpringMVC:Null Model... - bqwrhszmo
MyBatis-Improper inl... - 乐谱吧
good非常好 - diaba
@diaba:应该说是“时间的度量依据”... - diaba
如果速度增加接近光速、等于光速、甚至大于...
最新微语
- 在每件事情上花费的东西,就是生命的一部分,而我们花费的这些东西要求立即得到回报,或者在一个长时间以后得到回报。
2025-01-23 15:46
- 诺曼·文森特说:“并不是你认为自己是什么样的人,你就是什么样的人。但是你的思想是什么样,你就是什么样的人。”
2025-01-23 15:44
- 从今天起,做一个幸福的人。喂马,砍柴,(思想)周游世界
2022-03-21 23:31
- 2022.03.02 23:37:59
2022-03-02 23:38
- 几近崩溃后,找到解决方法,总是那么豁然开朗!所以遇到问题要坚持!
2018-07-18 10:49
发表评论: