LeetCode题目链接
https://leetcode.cn/problems/fibonacci-number/description/
https://leetcode.cn/problems/climbing-stairs/
https://leetcode.cn/problems/min-cost-climbing-stairs/description/
题解
509.斐波那契数
简单就过了。
70.爬楼梯
本题的初始化和递推公式遇到了一些难题,都是AI帮我反应出来的。
746.使用最小花费爬楼梯
写的挺惊险的,一开始dp数组定大小时仗了AI的帮助,定义大小为cost.size()+1,其实是结果还需要一位来存。
代码
cpp
//509.斐波那契数
#include <iostream>
#include <vector>
using namespace std;
class Solution {
public:
int fib(int n) {
vector<int> dp(n + 1, 0);
if (n == 0) return 0;
dp[0] = 0;
dp[1] = 1;
for (int i = 2;i <= n;i++)
dp[i] = dp[i - 1] + dp[i - 2];
return dp[n];
}
};
int main() {
int n1 = 2, n2 = 3, n3 = 4, n5 = 1;
Solution s;
printf("%d", s.fib(n5));
return 0;
}
cpp
//70.爬楼梯
#include <iostream>
#include <vector>
using namespace std;
class Solution {
public:
int climbStairs(int n) {
vector<int> dp(n + 1, 0);
dp[0] = 1;
dp[1] = 1;
for (int i = 2;i <= n;i++) {
dp[i] = dp[i - 1] + dp[i - 2];
}
return dp[n];
}
};
int main() {
int n1 = 2, n2 = 3;
Solution s;
printf("%d", s.climbStairs(n2));
return 0;
}
cpp
//746.使用最小花费爬楼梯
#include <iostream>
#include <vector>
using namespace std;
class Solution {
public:
int minCostClimbingStairs(vector<int>& cost) {
vector<int> dp(cost.size() + 1, 0);
dp[0] = cost[0];
dp[1] = cost[1];
for (int i = 2;i <= cost.size();i++) {
if (i != cost.size())
dp[i] = min(dp[i - 1], dp[i - 2]) + cost[i];
else
dp[i] = min(dp[i - 1], dp[i - 2]);
}
return dp[cost.size()];
}
};
int main() {
vector<int> cost1 = { 10,15,20 }, cost2 = { 1,100,1,1,1,100,1,1,100,1 };
Solution s;
printf("%d", s.minCostClimbingStairs(cost2));
return 0;
}