A93238.「CTSC2001」排序二叉树

提高+/省选-

通过率:0%

时间限制:1.00s

内存限制:256MB

题目描述

一个边长为 nn 的正三角形可以被划分成若干个小的边长为 11 的正三角形,称为单位三角形。如下图,边长为 33 的正三角形被分成三层共九个小的正三角形,我们把它们从顶到底,从左到右以 191 \sim 9 编号(见右图)。同理,边长为 nn 的正三角形可以划分成 n2n^2 个单位三角形。

图1

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

图2

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

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

输入格式

第一行是一个整数 nn,随后 4n24n^2 行,依次为三棱锥四个面上所填的数字。

输出格式

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

输入输出样例

  • 输入#1

    3
    19
    33
    32
    31
    29
    3
    5
    4
    30
    22
    25
    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

    输出#1

    17

说明/提示

$1 \leq n \leq 18 $

首页