1. 初级爬台阶 - 求最短步数

LC - 70

一次可以迈1-2个台阶,因此最短步数与前两个台阶有关。

Initial state: 第一阶:1步 ; 第二阶:1步

deduction function: f[n] = f[n - 1] + f[n - 2];

====可以推出,第三阶可以从第一阶迈出,可以从第二阶迈出,因此有两种可能。基本就是斐波那契数列求和。

public int climbStairs(int n) {
if(n == 0) return 1;
if(n == 1) return 1; int[] dp = new int[n];
dp[0] = 1;
dp[1] = 2; for(int i = 0 ; i < n - 2 ; i++){
dp[i + 2] = dp[i] + dp[i + 1];
} return dp[n - 1];
}

2. 求最短开销

LC - 746

每个台阶的cost不同,还是只能迈1-2个台阶,这回求到顶点的最小开销。

Initial state: 2个台阶以内最小开销为cost[0], cost[1]中的最小值。0->1->dist or 0->2->dist

deduction function: f[n] = Math.min(dp[n - 1], dp[n - 2]) + cost[n]

====> 因为可以从n-1阶跳,也可以从n-2阶跳,选开销最小的台阶。

====>注意:可以从n->dist,n-1->dist,两个点都是有效的,因此结果选两个点中最小的。

public int minCostClimbingStairs(int[] cost) {
int len = cost.length;
if(len == 0) return cost[0];
if(len == 1) return Math.min(cost[0], cost[1]); int[] dp = new int[len]; dp[0] = cost[0];
dp[1] = cost[1]; for(int i = 2 ; i < len ; i++){
dp[i] = Math.min(dp[i - 1], dp[i - 2]) + cost[i];
} return Math.min(dp[len - 1], dp[len - 2]);
}

3. 1的进阶版

步数是2的幂。求有多少种组合。

因此:f[n] = f[n - 1] + f[n - 2] + f[n - 4] + ... + f[1]

public static int countSteps(int n) {
int[] dp = new int[n + 1];
dp[0] = 1; for(int i = 0 ; i < n ; i++) {
if(i == 0 || i == 1) dp[i + 1] = i + 1;
else {
int j = 0, tmp = 0;
while(Math.pow(2, j) <= i + 1) {
tmp += dp[(int) (i + 1 - Math.pow(2, j))];
j++;
}
dp[i + 1] = tmp;
}
}
System.out.println(Arrays.toString(dp));
return dp[n];
}

莽就对了。。。

DP爬台阶问题的更多相关文章

  1. 70. Climbing Stairs(动态规划 爬台阶,一次只能爬1,2两节)

    You are climbing a stair case. It takes n steps to reach to the top. Each time you can either climb ...

  2. LeetCode OJ:Climbing Stairs(攀爬台阶)

    You are climbing a stair case. It takes n steps to reach to the top. Each time you can either climb ...

  3. 九度 1547 出入栈(递推DP)

    题目描述: 给定一个初始为空的栈,和n个操作组成的操作序列,每个操作只可能是出栈或者入栈.要求在操作序列的执行过程中不会出现非法的操作,即不会在空栈时执行出栈操作,同时保证当操作序列完成后,栈恰好为一 ...

  4. LeetCode-70-Climbing Stairs

    You are climbing a stair case. It takes n steps to reach to the top. Each time you can either climb ...

  5. SDOI 2019 R1游记

    $SDOI$ $2019$ $R1$游记 昨天才刚回来,今天就来写游记啦! Day -5: 做了一下去年省选的Day1,感觉很神仙. Day -4: 做了一下去年省选的Day2,感觉还是很神仙. Da ...

  6. 【leetcode】70-ClimbingStairs

    problem ClimbingStairs 题意: 爬台阶问题,每次可以爬1个或者两个台阶,问如果有n个台阶,可以有多少种方法爬到顶部? 解析: 对于n=1,有一种方法:n=2,有两种方法: 对于n ...

  7. 面试10大算法汇总——Java篇

    问题导读 1 字符串和数组 2 链表 3 树 4 图 5 排序 6 递归 vs 迭代 7 动态规划 8 位操作 9 概率问题 10 排列组合 11 其他 -- 寻找规律 英文版 以下从Java角度解释 ...

  8. 刷题70. Climbing Stairs

    一.题目说明 题目70. Climbing Stairs,爬台阶(楼梯),一次可以爬1.2个台阶,n层的台阶有几种爬法.难度是Easy! 二.我的解答 类似的题目做过,问题就变得非常简单.首先用递归方 ...

  9. 收藏一部山地车教学视频,Fabien Barel主讲及动作示范

    视频是由曾多次获得UCI速降赛的冠军车手Fabien Barel主讲及动作示范,讲解山地车越野的装备以及基本动作.视频中的要点说明我已经手录为文本,如果视频中没有看清的地方,也可以看文字. 骑行装备 ...

随机推荐

  1. Cartographer源码阅读(4):Node和MapBuilder对象2

    MapBuilder的成员变量sensor::Collator sensor_collator_; 再次阅读MapBuilder::AddTrajectoryBuilder方法.首先构造了mappin ...

  2. 2019.04.12 Head First

    第一节 认识python python.exe -V python 会进入解释器 quit()命令会退出解释器 IDEL,一个python的集成开发环境,能够利用颜色突出语法的编辑器,一个调试工具,P ...

  3. [CSS] Frequently used method or solutions for issues

    Stick button in right side in html Solution: //In the html <div class="float__button" & ...

  4. awk 同时指定多个分隔符

    $ echo "id: xxx(6667)xxx"|awk -F "[()]" '{print $2}' $ 6667 $ echo "abc[def ...

  5. 024-母版页MasterPage

    网站的布局通常是统一的,上面是Logo.菜单条.下面是公司地址.版权声明等.如果每个页面都重复做这些功能的话:重复性劳动.一旦修改那么每个页面都要修改..Net中一般用母版(MasterPage)技术 ...

  6. Python记录13:软件开发目录规范

    软件开发目录规范 开发一个软件,一个工程项目,一般应该具备以下的几个基本的文件夹和模块,当然,这并不是一成不变的,根据项目的不同会有一定的差异,不过作为一个入门级的新手,建议暂时按照以下的规范编写: ...

  7. Sitecore系统教程即时查阅编辑内容

    实时模式中的Sitecore 作为开发人员,我们经常需要在本地环境中使用代码和内容.在本地,能够立即看到任何内容更改,以节省时间和提高效率是有意义的.这是在实时模式下运行Sitecore.默认情况下, ...

  8. api测试工具

    在线接口测试 http://www.36nu.com/apiTest 使用Fiddler测试WebApi接口 https://www.cnblogs.com/weixing/p/5254836.htm ...

  9. 二进制包安装MYSQL——

    yum install libaio -y #安装mysql依赖包tar zxf mysql-5.5.59-linux-glibc2.12-x86_64.tar.gz mv mysql-5.5.59- ...

  10. java web 的 几种跨域方式