动态规划刷题

文章目录

动态规划

  1. 状态表示 :dp[i],表示dp表中i下标位置的值
  2. 状态转移方程 :以i位置位置的状态,最近的一步来划分问题,比如可以将状态拆分成前状态来表示现状态,dp[i] = dp[i-1] + dp[i-2] + dp[i-3]
  3. 初始化
  4. 填表顺序
  5. 返回值
    线性dp的状态表示dp[i]都是以某个位置为开头或者以某个位置为结尾

三步问题

题目解析

  1. 状态表示:以i为结尾,dp[i]是什么意思,是一共有多少种方法
  2. 状态转移方程:以i位置最近的一步来划分问题
  3. 初始化:dp[1] = 1,dp[2] = 2,dp[3] = 4
  4. 填表顺序:从左向右填表
  5. 返回值:返回dp[n]的状态

代码

cpp 复制代码
class Solution 
{
public:
    int waysToStep(int n) 
    {
        if(n == 1 || n == 2) return n;
        else if(n == 3) return 4;
        
        long long k = 1e9 + 7;

        vector<int> dp(n+1);
        dp[1] = 1,dp[2] = 2,dp[3] = 4;
        for(int i = 4;i <= n;i++)
        {
            dp[i] = (((dp[i-1] + dp[i-2]) % k) + dp[i-3]) % k;
        } 

        return dp[n];
    }
};
相关推荐
.格子衫.22 分钟前
真题卷001——算法备赛
算法
XiaoyaoCarter32 分钟前
每日一道leetcode
c++·算法·leetcode·职场和发展·二分查找·深度优先·前缀树
Hygge-star1 小时前
【数据结构】二分查找5.12
java·数据结构·程序人生·算法·学习方法
June`2 小时前
专题二:二叉树的深度搜索(二叉树剪枝)
c++·算法·深度优先·剪枝
好吃的肘子3 小时前
Elasticsearch架构原理
开发语言·算法·elasticsearch·架构·jenkins
胡耀超4 小时前
霍夫圆变换全面解析(OpenCV)
人工智能·python·opencv·算法·计算机视觉·数据挖掘·数据安全
软行4 小时前
LeetCode 每日一题 3341. 到达最后一个房间的最少时间 I + II
数据结构·c++·算法·leetcode·职场和发展
nlog3n4 小时前
Go语言交替打印问题及多种实现方法
开发语言·算法·golang
How_doyou_do4 小时前
备战菊厂笔试4
python·算法·leetcode
朱剑君4 小时前
第九天——贪心算法——非递减数组
算法·贪心算法