【LeetCode笔记】96. 不同的二叉搜索树(Java、动态规划)

文章目录

  • 题目描述
  • 代码 & 思路
      • 精简版 2.0

题目描述

  • 这道题其实不用构造数据结构
  • 二叉搜索树:只要利用这个结构的性质即可,即:左右两子,左小右大
  • 然后用动态规划来做,具体如何推导见思路部分
    在这里插入图片描述

代码 & 思路

  • 见注释
class Solution {public int numTrees(int n) {// G(n)代表1~n组成的二叉搜索树种类// f(i)代表i为root的n个结点二叉搜索树// 那么有G(n) = f(1) + f(2) + ... + f(n)// 又f(i) = G(i-1) * G(n-i),也就是左边种类数量 * 右边种类数量// dp[i] 就是 G[i],就是以i个结点组成的树的种类数量int[] dp = new int[n+1];// 众所周知,0个和1个的数量都是1dp[0] = 1;dp[1] = 1;// i代表i个结点,从2个开始算,n个结束// 每次得到一个G[i]for(int i=2;i < n+1;i++){// f(i) = G(i-1) * G(n-i),一次j循环加一个f(i)for(int j=1;j < i+1;j++){// 此处的 i 就是当前 n// 二叉树的性质在这体现dp[i] += dp[j-1] * dp[i-j]; }}return dp[n];}
}

精简版 2.0

class Solution {public int numTrees(int n) {int[] dp = new int[n + 1];dp[0] = 1;dp[1] = 1;for(int i = 2; i <= n; i++) {for(int j = 1; j <= i; j++) {dp[i] += dp[j - 1] * dp[i - j];}}return dp[n];}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/504570.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

oracle18c创建数据库,Oracle 18C 手工创建CDB

Oracle 18c For Exadata版本的介质已经发布&#xff0c;作为一名心急的老粉丝&#xff0c;欣喜的发现可以安装在普通的Linux平台。但是在通过DBCA建库的时候会报ORA-12754错误&#xff0c;不过这也难不倒万能的网络。图形界面不行&#xff0c;我们还可以手工建库&#xff0c;前…

【LeetCode笔记】98. 验证二叉搜索树(Java、dfs、中序遍历、二叉树)

文章目录题目描述代码 & 思路题目描述 二叉搜索树&#xff0c;应该满足中序遍历的结果是按顺序的。 比如例1是1&#xff0c;2&#xff0c;3&#xff1b;而例二是1&#xff0c;5&#xff0c;3&#xff0c;4&#xff0c;6&#xff0c;是错的 代码 & 思路 就是中序遍历…

【LeetCode笔记】101. 对称二叉树(Java、回溯)

文章目录题目描述代码 & 思路题目描述 回溯&#xff0c;由最小子树的镜像&#xff0c;得到次小子树的镜像判断&#xff0c;一直回溯到根结点即可 代码 & 思路 /*** Definition for a binary tree node.* public class TreeNode {* int val;* TreeNode left…

oracle数据库全数据库名,Oracle数据库中的 数据库域名、数据库名、全局数据库名、SID、数据库实例名、服务名 解释...

菜鸟雷区在配置listener.ora 和 tnsnames.ora 连接Oracle数据库服务器时&#xff0c;我们需要把 以下容易混淆的概念区分开来数据库域名数据库名全局数据库名SID数据库实例名服务名有图有真相安装Oracle数据库时我们指定的这些东西在配置时需要使用&#xff0c;真坑&#xff0c…

【LeetCode笔记】102. 二叉树的层序遍历(Java、队列、DFS)

文章目录题目描述代码 & 思路题目描述 按层次&#xff0c;那么先按序读完本层值&#xff0c;并且存入队列中&#xff0c;再根据队列走下一层的值即可 代码 & 思路 /*** Definition for a binary tree node.* public class TreeNode {* int val;* TreeNode …

【LeetCode笔记】104. 二叉树的最大深度(Java、DFS、二叉树)

文章目录题目描述代码 & 思路题目描述 全局变量ans&#xff0c;遍历一遍树更新ans即可带着 depth 跑 DFS 代码 & 思路 写成dfs了&#xff0c;确实是bfs /*** Definition for a binary tree node.* public class TreeNode {* int val;* TreeNode left;* …

【LeetCode笔记】121. 买卖股票的最佳时机 / 剑指 Offer 63. 股票的最大利润(Java、动态规划)

文章目录题目描述代码 & 思路初版代码更新啦&#xff5e;优化代码再次更新题目描述 讲道理&#xff0c;一眼dp 代码 & 思路 时间复杂度O(n)&#xff0c;不过可改进的地方还多&#xff0c;跑出来大概6ms。 初版代码 class Solution {public int maxProfit(int[] p…

【LeetCode笔记】25. K个一组翻转链表(Java、链表、递归)

文章目录题目描述思路 & 代码更新 - 精简版三刷 - 再更新版题目描述 审题很重要。。一开始以为是一组换两个&#xff0c;但是实际上是一组全部都要互换。字节超高频题&#xff01;要认真点记录 思路 & 代码 用回溯来做&#xff0c;可以分解成&#xff1a;每次都用h…

php request time,php中time()与$_SERVER[REQUEST_TIME]用法区别分析

php中time()与$_SERVER[REQUEST_TIME]用法区别分析发布于 2015-01-26 08:56:46 | 143 次阅读 | 评论: 0 | 来源: 网友投递PHP开源脚本语言PHP(外文名: Hypertext Preprocessor&#xff0c;中文名&#xff1a;“超文本预处理器”)是一种通用开源脚本语言。语法吸收了C语言、Java…

【LeetCode笔记】105. 从前序与中序遍历序列构造二叉树(Java、递归、二叉树、哈希表)

文章目录题目描述代码 & 思路题目描述 这题主要是考察前序、后序的性质&#xff0c;以及相互间的关系 代码 & 思路 前序&#xff1a;根 - 左 - 右&#xff1b; 中序&#xff1a;左 - 根 - 右&#xff0c;那么用前序数组的首位&#xff08;即根&#xff09;的值到中…

【LeetCode笔记】114. 二叉树展开为链表(Java、递归)

文章目录题目描述解法 & 思路思路一思路二题目描述 我佛了&#xff0c;这道题挺描述不明的&#xff0c;有坑&#xff0c;过不了oj建议马上看评论 or 题解 解法 & 思路 思路一 代码就不贴了&#xff0c;过不去先序遍历&#xff0c;按序存储val到一个ArrayList。然后用…

【LeetCode笔记】136. 只出现一次的数字(Java、位运算)

文章目录题目描述代码 & 思路题目描述 评论区一个评论很不错&#xff1a;不用额外空间&#xff0c;首先考虑位运算。 代码 & 思路 异或 ^ &#xff1a;相同得0与0得本身满足交换律那么好办了&#xff0c;abcdeabcd > aabbccdde > 0 0 0 0 e > e class So…

linux脚本写的计算器,一步步打造自己的linux命令行计算器

相信很多人&#xff0c;在工作中会需要使用到计算器。一般的做法是&#xff0c;打开并使用系统自带的计算器。这种做法可能对我来说&#xff0c;有如下几个问题。太慢。每次需要打开计算器&#xff0c;然后改成编程模式&#xff0c;手工选择进制&#xff0c;再使用输入表达式进…

【LeetCode笔记】141. 环形链表(Java、快慢指针、链表)

文章目录题目描述思路 & 代码题目描述 常见题&#xff0c;用上了久违的快慢指针 思路 & 代码 举个例子就能明白了&#xff1a;我和汽车&#xff0c;进行一场比赛&#xff0c;跑道可能是环形跑道&#xff0c;也可能是直道。直道的话&#xff0c;将会以汽车撞到终点为…

【LeetCode笔记】169. 多数元素(Java、摩尔投票法、哈希表)

文章目录题目描述思路 & 代码思路一&#xff1a;哈希表思路二&#xff1a; 摩尔投票法题目描述 好家伙&#xff0c;这是今天最有意思的题目了 思路 & 代码 思路一&#xff1a;哈希表 先说缺点&#xff1a;空间复杂度O(n)一次遍历&#xff0c;记录<数组存储值&a…

【LeetCode笔记】206. 反转链表(Java、迭代、递归、链表)

啊好久没更文了&#xff0c;前两天状态不太好。还是要坚持更文敲题噢&#xff01; 文章目录题目描述思路 & 代码题目描述 面试高频题&#xff0c;需要会用两种方法解决&#xff01;&#xff08;迭代 and 递归&#xff09;其实先写出迭代&#xff0c;递归就不难写了。 思…

当你抛弃windows使用linux,当我们厌倦了Windows系统还能考虑什么样的桌面操作系统?...

如果你厌倦了Windows&#xff0c;我们该选择什么样的操作系统&#xff1f;时间告诉我们&#xff0c;任何事物都不会一成不变&#xff0c;当我们厌倦了Windows那天到来&#xff0c;不妨考虑换个操作系统&#xff0c;即便Windows操作系统在市场依然如日中天&#xff0c;旧的不去新…

【LeetCode笔记】234. 回文链表(Java、快慢指针、链表)

文章目录题目描述思路 & 算法题目描述 写这道题前最好把206.翻转链表 写了有空间复杂度的话都好说&#xff0c;不管是新建链表、还是用字符串equals都好做。 思路 & 算法 快慢指针&#xff1a; 快指针找终点&#xff0c;慢指针反转前半个链表快指针回到慢指针的位…

vs2010 编译linux,VS2010 Boost编译安装

2.解压缩到D:\boost 目录下3.编译bjam(1)从vs2010的工具菜单进入命令提示窗口(单击“开始”按钮&#xff0c;指向“所有程序”&#xff0c;指向“Microsoft Visual Studio 2010”&#xff0c;指向“Visual Studio tools(工具)”&#xff0c;然后单击“Visual Studio 2010 comma…

【LeetCode笔记】200. 岛屿数量(Java、DFS)

文章目录题目描述代码 & 思路更新代码题目描述 直接毁岛&#xff01;每次发现一个岛&#xff0c;ans&#xff0c;然后直接把整个岛毁了&#xff08;感染&#xff09;直到最后&#xff0c;找出所有岛&#xff0c;此时地图上全都是’0’ 代码 & 思路 每次找到一个岛&…