9.9|day 2|整数拆分|不同的二叉搜索树

整数拆分:

复制代码
class Solution {
    public int integerBreak(int n) {
    int[] dp = new int[n+1];
    dp[2] =  1;
    for(int i = 3;i<=n;i++){
       for(int j = 1;j<=i-j;j++){
           dp[i] = Math.max(dp[i],Math.max(j*dp[i-j],j*(i-j)));
       }
    }//这里感觉要注意的就是j是我们要拆分的数,所以不会是dp[j]*dp[i-j],这种情况在代码的进行中会进行
       //因为j是从小到大进行的,拆分j的情况已经计算过了
        //感觉智商有点不够
        //从定义上来理解吧:j*dp[i-j]是将一个数拆分成两个及两个数以上,而dp[i-j]*dp[j]是将一个数默认拆分成四个数以上
        //前一种情况包括后一种,好像懂了
    return dp[n];
    }
}
复制代码
class Solution {
    public int numTrees(int n) {
    int[] dp = new int[n+1];
    dp[0] = 1;
    dp[1]  =1;//因为n的取值问题,所以不能写dp[2]
    for(int i = 2;i<=n;i++){
        for(int j  =1;j<=i;j++){
            ///dp[j-1]代表以j为头节点的左子树的最大二叉搜索树
            //dp[i-j]就是比j大的数,i是总数
            dp[i] += dp[j-1]*dp[i-j];
        }
    }
    return dp[n];
    }
}
相关推荐
沐怡旸8 分钟前
【算法】725.分割链表--通俗讲解
算法·面试
im_AMBER1 小时前
数据结构 04 栈和队列
数据结构·笔记·学习
L_09071 小时前
【Algorithm】Day-4
c++·算法·leetcode
代码充电宝2 小时前
LeetCode 算法题【简单】20. 有效的括号
java·算法·leetcode·面试·职场和发展
海琴烟Sunshine2 小时前
leetcode 119. 杨辉三角 II python
算法·leetcode·职场和发展
小杨的全栈之路2 小时前
霍夫曼编码:数据压缩的核心算法详解(附图解 + 代码)
算法
cjinhuo2 小时前
标签页、书签太多找不到?AI 分组 + 拼音模糊搜索,开源插件秒解切换难题!
前端·算法·开源
贝塔实验室2 小时前
频偏估计方法--快速傅里叶变换(FFT)估计法
网络协议·算法·数学建模·动态规划·信息与通信·信号处理·傅立叶分析
闭着眼睛学算法2 小时前
【双机位A卷】华为OD笔试之【模拟】双机位A-新学校选址【Py/Java/C++/C/JS/Go六种语言】【欧弟算法】全网注释最详细分类最全的华子OD真题题解
java·c语言·javascript·c++·python·算法·华为od
玉夏3 小时前
【每日算法C#】爬楼梯问题 LeetCode
算法·leetcode·c#