算法训练营Day40(动态规划)

今天两题都挺有难度,建议大家思考一下没思路,直接看题解,第一次做,硬想很难想出来。

343. 整数拆分

343. 整数拆分 - 力扣(LeetCode)

理解难度大,但学完其实很简单

java 复制代码
class Solution {
    public int integerBreak(int n) {
        //dp[i]:分拆数字i,可以得到的最大乘积为dp[i]。
        int [] dp = new int[n+1];
        dp[0]=0;
        dp[1]=0;
        dp[2]=1;
        for(int i = 3;i<=n;i++){
            for(int j = 1;j<=i/2;j++){
               dp[i] = Math.max(dp[i], Math.max(j*(i-j), j*dp[i-j]));
            }
        }
        return dp[n];
    }
}

96.不同的二叉搜索树

96. 不同的二叉搜索树 - 力扣(LeetCode)

二刷好好学下

java 复制代码
class Solution {
    public int numTrees(int n) {
        //初始化 dp 数组
        int[] dp = new int[n + 1];
        //初始化0个节点和1个节点的情况
        dp[0] = 1;
        dp[1] = 1;
        for (int i = 2; i <= n; i++) {
            for (int j = 1; j <= i; j++) {
                //对于第i个节点,需要考虑1作为根节点直到i作为根节点的情况,所以需要累加
                //一共i个节点,对于根节点j时,左子树的节点个数为j-1,右子树的节点个数为i-j
                dp[i] += dp[j - 1] * dp[i - j];
            }
        }
        return dp[n];
    }
}
相关推荐
专注前端30年31 分钟前
智能物流路径规划系统:核心算法实战详解
算法
json{shen:"jing"}1 小时前
字符串中的第一个唯一字符
算法·leetcode·职场和发展
追随者永远是胜利者1 小时前
(LeetCode-Hot100)15. 三数之和
java·算法·leetcode·职场和发展·go
BlockWay2 小时前
西甲赛程搬进平台:WEEX以竞猜开启区域合作落地
大数据·人工智能·算法·安全
im_AMBER4 小时前
Leetcode 121 翻转二叉树 | 二叉树中的最大路径和
数据结构·学习·算法·leetcode
mit6.8244 小时前
二分+贪心
算法
programhelp_5 小时前
特斯拉 MLE 超详细面经 + 避坑
数据结构·人工智能·算法·面试·职场和发展
越甲八千6 小时前
深入了解迭代器erase()之后的失效逻辑
算法
躺柒6 小时前
读人工智能全球格局:未来趋势与中国位势06人类的未来(下)
大数据·人工智能·算法·ai·智能
L_Aria6 小时前
6421. 【NOIP2019模拟11.11】匹配
c++·算法·动态规划