当前位置:网站首页>动态规划每日一练(2)
动态规划每日一练(2)
2022-08-02 08:40:00 【恶龙咆哮@~】
1.爬楼梯
假设你正在爬楼梯。需要 n 阶你才能到达楼顶。
每次你可以爬 1 或 2 个台阶。你有多少种不同的方法可以爬到楼顶呢?
我们用 f(x)f(x) 表示爬到第 xx 级台阶的方案数,考虑最后一步可能跨了一级台阶,也可能跨了两级台阶,所以我们可以列出如下式子:
f(x) = f(x - 1) + f(x - 2)
它意味着爬到第 xx 级台阶的方案数是爬到第 x - 1x−1 级台阶的方案数和爬到第 x - 2x−2 级台阶的方案数的和。很好理解,因为每次只能爬 11 级或 22 级,所以 f(x)f(x) 只能从 f(x - 1)f(x−1) 和 f(x - 2)f(x−2) 转移过来,而这里要统计方案总数,我们就需要对这两项的贡献求和。
class Solution {
public:
int climbStairs(int n) {
if(n<=2)
{
return n;
}
else{
int p=0,q=1,s=1;
for(int i=2;i<=n;i++)
{
p=q;
q=s;
s=q+p;
}
return s;
}
}
};
2.使用最少花费爬楼梯
给你一个整数数组 cost ,其中 cost[i] 是从楼梯第 i 个台阶向上爬需要支付的费用。一旦你支付此费用,即可选择向上爬一个或者两个台阶。
你可以选择从下标为 0 或下标为 1 的台阶开始爬楼梯。
请你计算并返回达到楼梯顶部的最低花费。
题解:dp问题
dp[i]=min(dp[i−1]+cost[i−1],dp[i−2]+cost[i−2])
class Solution {
public:
int minCostClimbingStairs(vector<int>& cost) {
int n=cost.size();
vector<int> dp(n+1);
dp[0]=0;
dp[1]=0;
for(int i=2;i<=n;i++)
{
dp[i]=min(dp[i-1]+cost[i-1],dp[i-2]+cost[i-2]);
}
return dp[n];
}
};
边栏推荐
猜你喜欢
随机推荐
自定义View实现波浪荡漾效果
Detailed explanation of calculation commands in shell (expr, (()), $[], let, bc )
向量组的线性相关性
next permutation
mysqldump --set-gtid-purged=OFF
QT web 开发 - 笔记 - 3
OneNote 教程,如何在 OneNote 中创建更多空间?
近期在SLAM建图和定位方面的进展
主流监控系统工具选型及落地场景参考
What is the function of page directive contentPage/pageEncoding in JSP page?
Redisson的看门狗机制
小康股份更名赛力斯,如何走出一条高端产品的“丝绸之路”?
PyQt5(一) PyQt5安装及配置,从文件夹读取图片并显示,模拟生成素描图像
Biotin-C6-amine|N-biotinyl-1,6-hexanediamine|CAS: 65953-56-2
Axial Turbine Privacy Policy
AI目标分割能力,无需绿幕即可实现快速视频抠图
下一个排列
C Language Basics_Union
Gorilla Mux 和 GORM 的使用方法
JS中的数组方法








