二叉搜索树的深度,二叉搜索树应用场景

  二叉搜索树的深度,二叉搜索树应用场景

  DP5有多少棵不同的二分搜索法树?

  描述给定的N个节点,节点值从1到N,请问这N个节点可以有多少种不同的方式组成不同的二分搜索法树?

  数据范围:

  描述:仅在一行中输入正整数N,表示节点数。

  输出描述:输出组成不同二分搜索法树的方法的数量。

  示例1输入:

  产出3:

  5例2输入:

  2:输出:

  2问题的解决方案动态规划解决方案假设dp[i]表示第二茬搜索树的方法的数量,第二茬搜索树可以由I个不同的元素组成。初始条件:dp[0]=dp[1]=1递归条件:对于dp[i],我们可以依次选择从1到I的树作为根节点。假设我们选择节点K,1=k=i,那么根据二叉树的性质,1 ~ 1[K 1,i]的个数只能放在根节点的右边,所以dp[i]=注:本来dp[0]按照我的理解应该是0,但是当我们选择I(或者1)作为根节点时,剩下的1~i-1个数应该放在左边。合成的方法是dp[i-1]。此时,如果我们乘以dp[0],

  代码如下:

  #包含位/标准数据。h

  整数求解(整数n)

  {

  如果(n=0)

  {

  返回0;

  }

  std:vector int dp(n 1,0);//dp[i]表示从第0步或第1步到达I时的最小值。

  DP[0]=1;

  DP[1]=1;

  for(int I=2;I=n;我)

  {

  for(int k=1;k=I;k)

  {

  DP[I]=DP[I]DP[k-1]* DP[I-k];

  }

  }

  返回DP . back();

  }

  int main()

  {

  int n,x;

  std:vector int成本;

  STD:CIN n;

  STD:cout solve(n)STD:endl;

  返回0;

  }

郑重声明:本文由网友发布,不代表盛行IT的观点,版权归原作者所有,仅为传播更多信息之目的,如有侵权请联系,我们将第一时间修改或删除,多谢。

相关文章阅读

  • office2010激活密钥大全 怎么永久激活office2010
  • project2010产品密钥免费_project2010激活密钥永久激活码
  • c语言调用退出函数 c语言退出整个程序怎么写
  • c语言中怎么给函数初始化 c语言的初始化语句
  • c语言编写函数计算平均值 c语言求平均函数
  • chatgpt是什么?为什么这么火?
  • ChatGPT为什么注册不了?OpenAI ChatGPT的账号哪里可以注册?
  • OpenAI ChatGPT怎么注册账号?ChatGPT账号注册教程
  • chatgpt什么意思,什么是ChatGPT ?
  • CAD中怎么复制图形标注尺寸不变,CAD中怎么复制图形线性不变
  • cad中怎么创建并使用脚本文件,cad怎么运行脚本
  • cad中快速计算器的功能,cad怎么快速计算
  • cad中快速修改单位的方法有哪些,cad中快速修改单位的方法是
  • cad中心点画椭圆怎么做,cad轴测图怎么画椭圆
  • CAD中常用的快捷键,cad各种快捷键的用法
  • 留言与评论(共有 条评论)
       
    验证码: