【算法与数据结构】746、LeetCode使用最小花费爬楼梯

文章目录

所有的LeetCode题解索引,可以看这篇文章------【算法和数据结构】LeetCode题解

一、题目

二、解法

  思路分析:本题可以从0阶或者1阶台阶开始,每次爬楼梯所需的花费是之前的花费dpi+从本层向上爬所需的costi d p i + c o s t i dpi+costi dpi+costi。可能到达第i阶台阶的情况有两种:从第i-2阶台阶一次性爬两步;从第i-1阶台阶一次性爬一步。因为要找到最小的花费,可以知道动态数组的表达式为: d p i = m i n ( d p i − 2 + c o s t i − 2 , d p i − 1 + c o s t i − 1 ) dpi = min(dpi-2+costi-2,dpi-1+costi-1) dpi=min(dpi−2+costi−2,dpi−1+costi−1)。

  程序如下:

cpp 复制代码
class Solution {
public:
	int minCostClimbingStairs(vector<int>& cost) {
		vector<int> dp(cost.size() + 1);	// 楼顶
		dp[0] = 0;
		dp[1] = 0;
		for (int i = 2; i <= cost.size(); i++) {
			dp[i] = min(dp[i-1] + cost[i-1], dp[i-2] + cost[i-2]);
		}
		return dp[cost.size()];
	}
};

复杂度分析:

  • 时间复杂度: O ( n ) O(n) O(n)。
  • 空间复杂度: O ( n ) O(n) O(n)。

三、完整代码

cpp 复制代码
# include <iostream>
# include <vector>
# include <algorithm>
using namespace std;

class Solution {
public:
	int minCostClimbingStairs(vector<int>& cost) {
		vector<int> dp(cost.size() + 1);	// 楼顶
		dp[0] = 0;
		dp[1] = 0;
		for (int i = 2; i <= cost.size(); i++) {
			dp[i] = min(dp[i-1] + cost[i-1], dp[i-2] + cost[i-2]);
		}
		return dp[cost.size()];
	}
};

int main() {
	vector<int> cost = { 1, 100, 1, 1, 1, 100, 1, 1, 100, 1 };
	Solution s1;
	int result = s1.minCostClimbingStairs(cost);
	cout << result << endl;
	system("pause");
	return 0;
}

end

相关推荐
KaMeidebaby9 分钟前
卡梅德生物技术快报|纯化重组蛋白实操详解
人工智能·python·tcp/ip·算法·机器学习
手写码匠1 小时前
从零实现 Prompt 工程引擎:结构化提示、自动优化与多轮自省体系
人工智能·深度学习·算法·aigc
无限码力1 小时前
阿里算法岗 0530笔试真题 - 多约束条件下的元素匹配统计
算法·阿里笔试真题·阿里机试真题·阿里算法岗笔试
lqqjuly2 小时前
MLA — 多头潜在注意力深度解析
深度学习·神经网络·算法
吴可可1232 小时前
SolidWorks草图转三维DWG技巧
算法
redaijufeng2 小时前
C++雾中风景7:闭包
c++·算法·风景
小欣加油3 小时前
leetcode287寻找重复数
数据结构·c++·算法·leetcode
尽兴-3 小时前
2.1 向量基础:Embedding、余弦相似度、欧氏距离、向量检索
算法·embedding·欧氏距离·向量检索·余弦相似度
Black蜡笔小新4 小时前
自动化AI算法训练服务器DLTM训推一体工作站赋能多行业智能化升级
人工智能·算法·自动化
怪兽学LLM4 小时前
LeetCode 438 找到字符串中所有字母异位词(Python 固定滑动窗口+字符计数解法)
python·算法·leetcode