码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 斐波那契模型系列【动态规划】


    动态规划步骤

    1、状态表示

    是什么:dp表(可能是一维或二维数组)里的值所表示的含义。

    怎么来:

    1、题目要求

    2、经验+题目要求

    3、发现重复子问题

    2、状态转移方程

    dp[i]=...

    3、初始化

    保证填表不越界

    4、填表顺序

    5、返回值

    写代码时,可以就按一下步骤:

    1、创建dp表

    2、初始化

    3、填表

    4、返回值 

    5、可能会需要处理边界

    一、第n个泰波那契数

     

    1. class Solution {
    2. public:
    3. int tribonacci(int n) {
    4. vector<int> dp(n+1);
    5. if(n==0) return 0;
    6. if(n==1||n==2) return 1;
    7. dp[0] = 0,dp[1] = 1,dp[2] = 1;
    8. for(int i = 3;i <= n;i++){
    9. dp[i] = dp[i-1] + dp[i-2] + dp[i-3];
    10. }
    11. return dp[n];
    12. }
    13. };

    空间优化------滚动数组

    将abcd向后平移。 

    1. class Solution {
    2. public:
    3. int tribonacci(int n) {
    4. if(n==0) return 0;
    5. if(n==1||n==2) return 1;
    6. int a = 0,b = 1,c = 1,d;
    7. for(int i = 3;i <= n;i++){
    8. d = a+b+c;
    9. a = b;
    10. b = c;
    11. c = d;
    12. }
    13. return d;
    14. }
    15. };

    二、三步问题 

     

    取模问题:每做一次加法就要做一次取模

    1. class Solution {
    2. public:
    3. int waysToStep(int n) {
    4. vector<int> dp(n+1);
    5. const int MOD = 1e9+7;
    6. if(n == 1||n == 2) return n;
    7. if(n == 3) return 4;
    8. dp[1] = 1,dp[2] = 2,dp[3] = 4;
    9. for(int i = 4;i <= n;i++){
    10. dp[i] = ((dp[i-1]+dp[i-2])%MOD+dp[i-3])%MOD;
    11. }
    12. return dp[n];
    13. }
    14. };

    三、最小花费爬楼梯

    注意:楼顶是最后一个台阶的下一个位置。

     

    1. class Solution {
    2. public:
    3. int minCostClimbingStairs(vector<int>& cost) {
    4. int n = cost.size();
    5. vector<int> dp(n + 1);
    6. dp[0] = dp[1] = 0;
    7. for(int i = 2;i <= n;i++){
    8. dp[i] = min(dp[i-1]+cost[i-1],dp[i-2]+cost[i-2]);
    9. }
    10. return dp[n];
    11. }
    12. };

     四、解码方法

     注意:dp[i-1]和dp[i-2]是解密成功才加的。

    优化版初始化(更好处理边界)

    把数组统一往后移一位,开多一位 。

    1. class Solution {
    2. public:
    3. int numDecodings(string s) {
    4. int n = s.size();
    5. vector<int> dp(n + 1);
    6. dp[0] = 1;
    7. dp[1] = s[0] != '0';
    8. for(int i = 2;i <= n;i++){
    9. if(s[i-1] != '0') dp[i] += dp[i-1];
    10. int t = (s[i-2]-'0')*10 + s[i-1]-'0';
    11. if(t <= 26 && t >= 10) dp[i] += dp[i-2];
    12. }
    13. return dp[n];
    14. }
    15. };

  • 相关阅读:
    磁盘IO体系架构与存储解决方案
    JAVA JSP javaweb小区物业管理系统源码 小区管理系统 jsp小区物业服务管理系统
    Sentinel核心算法设计与实现
    sql中可以使用不在select中的字段排序
    21-前端与后端动静分离
    【微信小程序】一文带你读懂云开发
    Verilog仿真跨模块调用内部信号的方法
    焦虑经济衍生冥想生意,年轻人会为“放空”买单吗?
    Linux 软链接 和 硬链接
    【pwn】2022 祥云杯 部分wp
  • 原文地址:https://blog.csdn.net/m0_73065213/article/details/133551754
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号