3702: 二叉树
Time Limit: 15 Sec Memory Limit: 256 MB
Submit: 509 Solved: 230
[Submit][Status][Discuss]
Description
现在有一棵二叉树,所有非叶子节点都有两个孩子。在每个叶子节点上有一个权值(有n个叶子节点,满足这些权值为1..n的一个排列)。可以任意交换每个非叶子节点的左右孩子。
要求进行一系列交换,使得最终所有叶子节点的权值按照中序遍历写出来,逆序对个数最少。
Input
第一行n
下面每行,一个数x
如果x==0,表示这个节点非叶子节点,递归地向下读入其左孩子和右孩子的信息,
如果x!=0,表示这个节点是叶子节点,权值为x。
Output
一行,最少逆序对个数。
Sample Input
3
0
0
3
1
2
Sample Output
1
HINT
对于100%的数据:2<=n<=200000。
Source
【分析】
二叉树有许多好(wu)玩(liao)的性质。
中序遍历是中左右,由于一个非叶子结点没有权值,其实顺序就是左右。
我们发现对于一个节点x,它的左儿子L,右儿子R,无论儿子的子树怎么换,对该节点统计的答案都没有影响。
所以我们要用一个数据结构来维护一下这个东西 -> 机智的线段树合并!
贪心求解!