1603 限高二叉排列树
题目来源: CodeForces
基准时间限制:1 秒 空间限制:131072 KB 分值: 40 难度:4级算法题

作为游戏魔方的编写者和管理员,Bob在很多主存模块中检测游戏魔方,并且Bob从未被用户打败,同时他也经常和游戏魔方作战。

然而,不愉快的事情发生了,游戏《失落的洛杉矶》崩溃了,由于出现了一个非常可恶的病毒——“十六进制”,它非常奇怪,并且非常喜欢玩,因此,Bob必须先和它玩,才能和别人玩。

此次“十六进制”发明了以下游戏:Bob必须通过一些有n个节点的二叉搜索树,二叉搜索树是一颗二叉树,每个节点有一个唯一的关键字。我们来说一下二叉搜索树的性质,以下规则在每个节点上都成立:每个节点的关键字都大于左子树上的所有节点的关键字,都小于右子树上所有节点的关键字。每个关键字都是从1~n的不同的正整数。每棵树上的所有节点都最多有两个子节点,或者没有子节点(在这种情况下的节点被称为叶子节点)。

在“十六进制”的游戏中,所有的树都是不同的,但是每棵树的高度都不低于h。在此问题中,“高度”指的是从根节点到最远的叶子节点的最多节点数(包含叶子节点和根节点)。当Bob跳过一棵树的后,这棵树会消失。当所有的树都消失了,Bob就通过了游戏魔方。他想知道在最坏的情况下,他必须跳过多少棵树,你能帮助他吗?

Input
单组测试数据
输入数据包含两个以空格隔开的正整数n和h (1<=n<=35,1<=h<= n) 。
Output
输出一个整数表示问题的答案。题目保证这个整数不超过9*10^18。
Input示例
3 2
Output示例
5

//对于DP还是不够强啊,想到一部分,但还是没有找到状态方程按理说,性质很容易发现,二叉搜索树,如果根节点确定,那么,左右树的节点数就一定了然而我想的是dp[i][j]为根为 i ,j 高度的种数,然后思索了半天,发现并不好dp,唉假如 dp[i][j] 是 i 个节点,高度小于等于 j 的个数的话,就非常好做了、、、

 1 #include<bits/stdc++.h>
 2 using namespace std;
 3
 4 #define LL long long
 5 #define eps 1e-8
 6 #define MX 40
 7
 8 int n,h;
 9 LL dp[MX][MX];
10
11 int main()
12 {
13     while (scanf("%d%d",&n,&h)!=EOF)
14     {
15         memset(dp,0,sizeof(dp));
16         for (int i=0;i<=n;i++)
17             dp[0][i]=1;
18         for (int i=1;i<=n;i++)
19             for (int j=1;j<=n;j++)
20                 for (int k=1;k<=i;k++)
21                     dp[i][j]+=dp[k-1][j-1]*dp[i-k][j-1];
22         printf("%lld\n",dp[n][n]-dp[n][h-1]);
23     }
24     return 0;
25 }

View Code

转载于:https://www.cnblogs.com/haoabcd2010/p/7545033.html

1603 限高二叉排列树(计数DP)相关推荐

  1. 51nod 1603 限高二叉排列树(求补思想-DP)

    1603 限高二叉排列树 题目来源:  CodeForces 基准时间限制:1 秒 空间限制:131072 KB 分值: 40  难度:4级算法题  收藏  关注 作为游戏魔方的编写者和管理员,Bob ...

  2. 51nod-1603 限高二叉排列树

    原题链接 1603 限高二叉排列树 题目来源:  CodeForces 基准时间限制:1 秒 空间限制:131072 KB 分值: 40  难度:4级算法题  收藏  关注 作为游戏魔方的编写者和管理 ...

  3. 树形结构:二叉排列树,二叉搜索树

    二叉排列树,二叉搜索树 这个数听见得比较多,含义是:左边<=中间<=右边,换句话来说使用中序遍历最后得到结果就是一个有序得序列. 建立一颗二叉排列树 class BinTNode:def ...

  4. 二叉苹果树(树型DP+背包)

    二叉苹果树 有一棵苹果树,如果树枝有分叉,一定是分2叉(就是说没有只有1个儿子的结点).这棵树共有N个结点(叶子点或者树枝分叉点),编号为1-N,树根编号一定是1. 我们用一根树枝两端连接的结点的编号 ...

  5. 1597. 根据中缀表达式构造二叉表达式树 双端队列

    1597. 根据中缀表达式构造二叉表达式树 给定 pushed 和 popped 两个序列,每个序列中的 值都不重复,只有当它们可能是在最初空栈上进行的推入 push 和弹出 pop 操作序列的结果时 ...

  6. hdu 1561 The more, The Better_树状dp

    题目链接 题意:给你一棵树,各个节点都有价值(除根节点),从根节点出发,选择m个节点,问最多的价值是多小. 思路:很明显是树状dp,遍历树时背包最优价值,dp[i][k]=max{dp[i][r]+d ...

  7. 【CVPR2020-中科院-腾讯优图】基于注意力卷积二叉神经树的细粒度视觉分类

    关注上方"深度学习技术前沿",选择"星标公众号", 资源干货,第一时间送达! 本文由腾讯优图实验室和中科院软件所联合提出.细粒度视觉分类(Fine-Graine ...

  8. [APIO2018] Duathlon 铁人两项 圆方树,DP

    [APIO2018] Duathlon 铁人两项 LG传送门 圆方树+简单DP. 不会圆方树的话可以看看我的另一篇文章. 考虑暴力怎么写,枚举两个点,答案加上两个点之间的点的个数. 看到题面中的一句话 ...

  9. 其他OJ 树型DP 选课

    在朱全民的PPT介绍的一个树型DP经典题,<选课>,中文题目,不结束 找了很久找到了可以提交的OJ,重庆八中 http://www.cqoi.net:2012/JudgeOnline/pr ...

最新文章

  1. RabbitMQ学习系列(五): RPC 远程过程调用
  2. JavaScript中类型检测
  3. android 特色输入输出
  4. Cloud for Customer的工作中心(work center)加载源代码
  5. 怎样选择合适的PoE交换机?POE交换机选用小常识!
  6. UVA10285 Longest Run on a Snowboard【DFS+记忆化搜索】
  7. HarmonyOS 组件篇
  8. 12. Element attributes 属性
  9. GIMP:图层蒙版应用小例
  10. 重装系统后,没有以太网和WLAN怎么办
  11. 写给四年前刚开始编程的自己
  12. Scipy-kmeans聚类色彩提取
  13. MyISAM与InnoDB存储引擎
  14. 又一AI大牛重返学界! 原京东高级副总裁周伯文受聘为清华电子工程系长聘教授...
  15. 2021-09-30《工程技术》期刊发表
  16. 关于学校熄灯时间的调研
  17. 来认识一下这些基于好友关系链和算法推荐的电影发现产品
  18. 知识图谱构建技术综述-2.3知识推理-学习笔记
  19. 《世界因你不同(李开复自传)》
  20. 深度学习强化学习进化计算 入门资源整理

热门文章

  1. php yii model,Yii模型
  2. android studio导出apk_Android 应用构建速度提升的十个小技巧
  3. sqlyog能连接oracle吗_真的能改变传统投影吗?支持各种无线连接,投影老巨头明基放大招...
  4. Maximum Xor Secondary CodeForces - 281D (单调栈)
  5. 《密码与安全新技术专题》第11周作业
  6. c#中引用类型作为值参数和引用参数问题
  7. Delphi关于StringGrid的公用模块[转]
  8. 快速找到由程序员到CTO发展道路上的问路石
  9. 多线程下局部变量与全局变量的使用及区别
  10. C++ socket 通信客户端和服务器端