题目名称 1170. 排序二叉树
输入输出 bstree.in/out
难度等级
时间限制 1000 ms (1 s)
内存限制 128 MiB
测试数据 10
题目来源 Gravatar王者自由 于2012-10-17加入
开放分组 全部用户
提交状态
分类标签
最小生成树 贪心
分享题解
通过:8, 提交:21, 通过率:38.1%
GravatarceerRep 100 0.032 s 5.22 MiB C++
GravatarceerRep 100 0.034 s 5.22 MiB C++
GravatarceerRep 100 0.034 s 5.53 MiB C++
GravatarceerRep 100 0.049 s 4.17 MiB C++
GravatarceerRep 100 0.075 s 15.92 MiB C++
GravatarNVIDIA 100 0.076 s 0.16 MiB Pascal
Gravatarcsgc0131123 100 0.113 s 27.75 MiB C++
Gravatar旺仔小馒头 100 0.127 s 51.64 MiB C++
GravatarceerRep 90 0.075 s 14.33 MiB C++
GravatarceerRep 60 0.244 s 3.54 MiB C++
关于 排序二叉树 的近10条评论(全部评论)
P跟我没有关系,恩就这样。
GravatarNVIDIA
2015-10-27 19:39 3楼
跟排序二叉树算法没有任何关系的题
GravatarNVIDIA
2015-10-27 19:39 2楼
警告输入格式打的有误,但是不影响评测机评测数据,不要拿他给的测试数据,这是正常的。我就这样浪费了很多时间QAQ
bstree.in
3
19 33 32 31 29 3 5 4 30
22 24 20 21 12 24 23 34 35
14 13 15 26 18 17 8 16 27
11 10 9 1 28 7 2 6 36
bstree.out
17
GravatarNVIDIA
2015-08-17 14:04 1楼

1170. 排序二叉树

★   输入文件:bstree.in   输出文件:bstree.out   简单对比
时间限制:1 s   内存限制:128 MiB

【问题描述】

一个边长为n的正三角形可以被划分成若干个小的边长为1的正三角形,称为单位三角形。

如右图,边长为3的正三角形被分成三层共9个小的正三角形,我们把它们从顶到底,从左到右以1~9编号,见右图。同理,边长为n的正三角形可以划分成n2个单位三角形。

 四个这样的边长为n的正三角形可以组成一个三棱锥。我们将正三棱锥的三个侧面依顺时针次序(从顶向底视角)编号为A, B, C,底面编号为D。侧面的A, B, C号三角形以三棱锥的顶点为顶,底面的D号三角形以它与AB三角形的交点为顶。左图为三棱锥展开后的平面图,每个面上标有圆点的是该面的顶,该图中侧面A, B, C分别向纸内方向折叠即可还原成三棱锥。我们把这A,B、C、D四个面各自划分成n2个单位三角形。

   对于任意两个单位三角形,如有一条边相邻,则称它们为相邻的单位三角形。显然,每个单位三角形有三个相邻的单位三角形。现在,把14n2分别随机填入四个面总共4n2个单位三角形中。

    现在要求你编程求由单位三角形组成的最大排序二叉树。所谓最大排序二叉树,是指在所有由单位三角形组成的排序二叉树中节点最多的一棵树.对于任一单位三角形,可选它三个相邻的单位三角形中任意一个作为父节点,其余两个分别作为左孩子和右孩子。当然,做根节点的单位三角形不需要父节点,而左孩子和右孩于对于二叉树中的任意节点来说并不是都必须的。



【输入格式】

第一行是一个整数n(1<=n<=18),随后的4n^2个数,依次为三棱锥四个面上所填的数字。

【输出格式】

仅包含一个整数,表示最大的排序二又树所含的节点数目。

【样例输入】

3
19 33 32 31 29 3 5 4 30
22 24 20 21 12 24 23 34 35
14 13 15 26 18 17 8 16 27
11 10 9 1 28 7 2 6 36

【样例输出】

17

【样例解释】

输入文件对应下图:

输出样例文件对应的最大排序二叉树如下图所示: