[Java 算法] 动态规划(1)

练习一 : 第 n 个泰波那契数

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

java 复制代码
class Solution {
    public int tribonacci(int n) {
        if(n == 0){
            return 0;
        }if(n == 1||n == 2){
            return 1;
        }
        int[] dp = new int[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];
    }
}

练习二 : 三步问题

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

java 复制代码
class Solution {
    public int waysToStep(int n) {
        // 边界条件
        if (n == 0 || n == 1) return 1;
        if (n == 2) return 2;
        
        // 用long避免整数溢出,无需硬编码特殊值
        long[] dp = new long[n + 1];
        dp[0] = dp[1] = 1;
        dp[2] = 2;
        int mod = 1000000007;
        
        for (int i = 3; i <= n; i++) {
            // 分步取模,确保每一步都不溢出
            dp[i] = (dp[i-1] + dp[i-2] + dp[i-3]) % mod;
        }
        
        // 最终转int返回
        return (int) dp[n];
    }
}

练习三 : 使用最小花费爬楼梯

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

java 复制代码
class Solution {
    public int minCostClimbingStairs(int[] cost) {
        int n = cost.length;
        int[] dp = new int[n+1];
        dp[0] = 0;
        dp[1] = 0;
        for(int i = 2;i<=n;i++){
            dp[i] = Math.min(dp[i-1]+cost[i-1],dp[i-2]+cost[i-2]);
        }
        return dp[n];
    }
}

状态表示 : dp[i] = 到达第 i 级台阶所需要的最小花费

状态转移方程 : dp[i] = min(dp[i-1]+cost[i-1],dp[i-2]+cost[i-2])

相关推荐
小O的算法实验室10 分钟前
2026年IEEE TITS,面向按需外卖配送调度的特定问题知识与基于学习元启发式算法,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
加勒比海带6612 分钟前
目标检测算法——农林行业数据集汇总附下载链接【Plant】
大数据·图像处理·人工智能·算法·目标检测
洛水水13 分钟前
【力扣100题】23. 螺旋矩阵
算法·leetcode·矩阵
影sir39 分钟前
不同测试数据下,该如何选择算法
算法·深度优先
潇湘散客1 小时前
CAX软件插件化设计实现牛刀小试
c++·算法·图形学·opengl
速易达网络1 小时前
2026,视觉算法正在经历一场静默革命
算法
WBluuue2 小时前
Codeforces 1094 Div1+2(ABCDE)
c++·算法
TENSORTEC腾视科技2 小时前
腾视科技大模型一体机解决方案:低成本私有化落地,重塑行业智能应用新格局
大数据·人工智能·科技·算法·ai·零售·大模型一体机
夏日听雨眠2 小时前
数据结构(循环队列)
数据结构·算法·链表
平行侠2 小时前
30MacLaren-Marsaglia算法故事文件
数据结构·算法