【算法练习】leetcode算法题合集之动态规划篇

普通动规系列

LeetCode343. 整数拆分

LeetCode343. 整数拆分

将10的结果存在索引为10的位置上,需要保证数组长度是n+1,索引的最大值是n,索引是从0开始的。

n的拆分,可以拆分为in-i,当然i可以继续拆分。而且拆分为n-1和1的结果和n-22的结果的大小也是不一定的。

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

    }
}

LeetCode70. 爬楼梯(⭐️Hot100 腾讯)

LeetCode70. 爬楼梯

需要考虑n==1的情况。

java 复制代码
class Solution {
    public int climbStairs(int n) {
        int[] dp = new int[n + 1];
        dp[1] = 1;
        dp[0] = 1;
        for (int i = 2; i <= n; i++) {
            dp[i] = dp[i - 1] + dp[i - 2];
        }
        return dp[n];
    }
}
相关推荐
大闲在人4 小时前
8. 供应链与制造过程术语:产能
算法·制造·供应链管理·智能制造·工业工程
一只小小的芙厨4 小时前
寒假集训笔记·以点为对象的树形DP
c++·算法
历程里程碑4 小时前
普通数组----合并区间
java·数据结构·python·算法·leetcode·职场和发展·tornado
执风挽^4 小时前
Python基础编程题2
开发语言·python·算法·visual studio code
Z9fish4 小时前
sse哈工大C语言编程练习20
c语言·开发语言·算法
晓13134 小时前
第六章 【C语言篇:结构体&位运算】 结构体、位运算全面解析
c语言·算法
iAkuya5 小时前
(leetcode)力扣100 61分割回文串(回溯,动归)
算法·leetcode·职场和发展
梵刹古音5 小时前
【C语言】 指针与数据结构操作
c语言·数据结构·算法
VT.馒头5 小时前
【力扣】2695. 包装数组
前端·javascript·算法·leetcode·职场和发展·typescript
CoderCodingNo6 小时前
【GESP】C++五级练习题 luogu-P1865 A % B Problem
开发语言·c++·算法