当前位置: 首页 > news >正文

Leetcode-894-所有可能的真二叉树-c++

题目详见https://leetcode.cn/problems/all-possible-full-binary-trees/

主搞动态规划,因为这玩意儿我还不是很懂

关于节点个数为奇数偶数的证明请见官方题解方法一中的如下内容:
在这里插入图片描述

这里DP的一个主要思想是:对于任何一个满二叉树,如果我们去掉根节点,那么剩下的部分就是两个更小的满二叉树。因此,我们可以通过将更小的满二叉树组合在一起来生成更大的满二叉树。

  • 这就是为什么在代码中有两个嵌套的循环。
  • 外层循环遍历所有的 i,代表我们想要生成的满二叉树的节点数量。
  • 内层循环遍历所有的 j,代表左子树的节点数量。
  • 因为满二叉树的节点总数必须是奇数(每个非叶节点都有两个子节点),所以 i 和 j 都是以 2 的步长增加的
  • 对于每个 j,代码会遍历 dp[j] 和 dp[i-1-j] 中的所有可能的左子树和右子树。然后,它会创建一个新的满二叉树,其左子树和右子树分别是当前的左子树和右子树,然后将这个新的满二叉树添加到 dp[i] 中。

光看也不好理解,这里提供 n=7 的时候最后的dp数组的样子

{
此处偶数位为空, // dp[0]
{[0]}, // dp[1]
此处偶数位为空, // dp[2]
{[0,0,0]}, // dp[3], 这里不要数数组的长度,而要数节点(0)的个数
此处偶数位为空,
{[0,0,0,null,null,0,0], [0,0,0,0,0]}, // dp[5]
此处偶数位为空,
{[0,0,0,null,null,0,0,null,null,0,0], [0,0,0,null,null,0,0,0,0], [0,0,0,0,0,0,0], [0,0,0,0,0,null,null,null,null,0,0], [0,0,0,0,0,null,null,0,0]} // dp[7]
}

  • 大家可以试试使用 d p [ a ] + 0 ( 这是个节点 ) + d p [ b ] dp[a] + 0(这是个节点) + dp[b] dp[a]+0(这是个节点)+dp[b] 来拼 d p [ a + b + 1 ] dp[a+b+1] dp[a+b+1]
  • 比如使用 d p [ 1 ] + 0 ( 这是个节点 ) + d p [ 5 ] dp[1] + 0(这是个节点) + dp[5] dp[1]+0(这是个节点)+dp[5] 来拼 d p [ 7 ] dp[7] dp[7]

笔者也在新手学习期中,所写的内容主要与大家交流学习使用,如有发现任何问题敬请指正!

http://www.lryc.cn/news/331346.html

相关文章:

  • Django DRF视图
  • SQLite全文搜索引擎:实现原理、应用实践和版本差异
  • day17-二叉树part04
  • 书生浦语第一次课
  • UE小:UE5.3无法创建C++工程
  • FFmpeg获取视频详情
  • find: paths must precede expression
  • RabbitMQ3.x之九_Docker中安装RabbitMQ
  • vue快速入门(四)v-html
  • 第19次修改了可删除可持久保存的前端html备忘录:换了一个特别的倒计时时钟
  • C++ 2024-4-1 作业
  • 【滑动窗口】Leetcode 串联所有单词的子串
  • golang channel实践代码及注意事项
  • 面试题:RabbitMQ 消息队列中间件
  • wpf中引用自定义字体
  • 高效准确!指甲剪盖片视觉检测技术解密
  • 分布式IO模块PLC扩展模拟量模块
  • Qt事件系统
  • C++STL--排序算法
  • CEF的了解
  • 基于OrangePi Zero2的智能家居项目(开发阶段)
  • 数据结构记录
  • 从零到一:基于 K3s 快速搭建本地化 kubeflow AI 机器学习平台
  • kettle使用MD5加密增量获取接口数据
  • PS入门|黑白色的图标怎么抠成透明背景
  • android 14 apexd分析(2)apexd 启动
  • 微信小程序怎么制作?制作一个微信小程序需要多少钱?
  • WPS二次开发专题:如何获取应用签名SHA256值
  • Flink SQL系列之:基于Flink SQL查询Topic中序列化的Debezium数据格式字段
  • 【WPF应用30】WPF中的ListBox控件详解