PART17 一维动态规划

第N个泰波那契数

lc.1137

cpp 复制代码
class Solution {
public:
    int tribonacci(int n) {
        if (n == 0) {
            return 0;
        }
        if (n <= 2) {
            return 1;
        }
        int dp[n + 1];
        dp[0] = 0;
        dp[1] = 1;
        dp[2] = 1;
        for (int i = 3; i <= n; i++) {
            dp[i] = dp[i - 1] + dp[i - 2] + dp[i - 3];
        }
        return dp[n];
    }
};

使用最小花费爬楼梯

lc.746

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

打家劫舍

lc.198

cpp 复制代码
class Solution {
public:
    int rob(vector<int>& nums) {
        int n = nums.size();
        if (n == 1) {
            return nums[0];
        }
        if (n == 2) {
            return max(nums[0], nums[1]);
        }
        int dp[n];
        dp[0] = nums[0];
        dp[1] = max(nums[0],nums[1]);
        for (int i = 2; i < n; i++) {
            dp[i] = max(dp[i - 1], dp[i - 2] + nums[i]);
        }
        return dp[n - 1];
    }
};

多米诺和托米诺平铺

cpp 复制代码
class Solution {
public:
    int numTilings(int n) {
        if (n <= 2) {
            return n;
        }
        vector<long long> f(n + 1);
        f[0] = 1;
        f[1] = 1;
        f[2] = 2;
        long long y = f[0];
        for (int i = 3; i <= n; i++) {
            f[i] = (f[i - 1] + f[i - 2] + 2 * y) % (1000000007);
            y += f[i - 2];
        }
        return f[n];
    }
};
相关推荐
汉克老师9 小时前
GESP6级C++考试语法知识(五、格雷码)
c++·算法·位运算·异或·gesp6级·gesp六级·格雷码
Ulyanov9 小时前
《从质点到位姿:基于Python与PyVista的导弹制导控制全栈仿真》: 可视化革命——基于 PyVista 的 3D 战场构建与实时渲染
开发语言·python·算法·3d·系统仿真
,,?!,9 小时前
数据结构算法-排序算法
数据结构·算法·排序算法
南境十里·墨染春水10 小时前
linux学习进展 守护进程
linux·服务器·学习
小白编程锤炼10 小时前
深入解析:质量门禁
人工智能·算法·架构·vibe-coding
Ares-Wang10 小时前
AI》》 监督学习,无监督学习,半监督学习、强化学习 、深度学习 统计学的常用方法
人工智能·深度学习·学习
Bechamz10 小时前
大数据开发学习Day31
大数据·学习·ajax
程序leo源10 小时前
C语言知识总结
c语言·开发语言·c++·经验分享·笔记·青少年编程·c#
沫璃染墨10 小时前
二叉搜索树完全指南:从核心原理到增删查改全实现
开发语言·c++
‎ദ്ദിᵔ.˛.ᵔ₎10 小时前
C++哈希表
数据结构·c++·散列表