您的位置:首页 > 房产 > 建筑 > 【leetcode C++】动态规划

【leetcode C++】动态规划

2025/1/28 3:23:52 来源:https://blog.csdn.net/2301_79789645/article/details/142106828  浏览:    关键词:【leetcode C++】动态规划

动态规划解题思路

1. 状态表示

dp表 里面的值所代表的含义(1.根据题目要求得出 2.经验 + 题目要求 3.分析问题过程中,发现重要子问题)

2. 状态转移方程

dp[i] 等于什么

3. 初始化

保证填表不越界

4. 填表顺序

为了填写该状态的时候,所需的状态已知

5. 返回值

题目要求 + 状态表示

6. 空间优化(平时做题可以不用考虑,面试复习)

一般用到滚动数组(仅仅需要若干状态)

 

1. 1137. 第 n 个泰波那契数

题目:

泰波那契序列 Tn 定义如下:

T0 = 0, T1 = 1, T2 = 1, 且在 n >= 0 的条件下 Tn+3 = Tn + Tn+1 + Tn+2

给你整数 n,请返回第 n 个泰波那契数 Tn 的值。

题目链接

1137. 第 N 个泰波那契数 - 力扣(LeetCode)

文字分析

这里还可以进行空间优化:

这里用到 滚动数组,只需要三个数,就可以得到第 i 个数的值,开空间可以节省

代码

class Solution {
public:int tribonacci(int n) {int a = 0,b = 1,c = 1;if(n == 0){return 0;}if(n < 3){return 1;}for(int i = 3;i <= n;i++){int d = a + b + c;a = b;b = c;c = d;}return c;}
};

 

2. 08.01 三步问题

题目:

三步问题。有个小孩正在上楼梯,楼梯有n阶台阶,小孩一次可以上1阶、2阶或3阶。实现一种方法,计算小孩有多少种上楼梯的方式。结果可能很大,你需要对结果模1000000007。

题目链接

11面试题 08.01. 三步问题 - 力扣(LeetCode)

文字分析

注意:

数据过大,储存会有误

在填表的时候,发生加法可以取模

代码

class Solution {
public:int waysToStep(int n) {vector<int> s(n + 1);if(n == 1){return 1;} if(n == 2){return 2;} if(n == 3){return 4;}s[0] = 0;s[1] = 1;s[2] = 2;s[3] = 4;for(int i = 4;i <= n;i++){s[i] =( (s[i - 1] + s[i - 2]) %  1000000007 + s[i - 3] )% 1000000007;}return s[n];}
};

3. 746 使用最小花费爬楼梯

题目:

给你一个整数数组 cost ,其中 cost[i] 是从楼梯第 i 个台阶向上爬需要支付的费用。一旦你支付此费用,即可选择向上爬一个或者两个台阶。

你可以选择从下标为 0 或下标为 1 的台阶开始爬楼梯。

请你计算并返回达到楼梯顶部的最低花费。

题目链接

746. 使用最小花费爬楼梯 - 力扣(LeetCode)

文字分析

 代码

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

 

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com