#P1864. [NOI2009] 二叉查找树

    ID: 889 远端评测题 1000ms 125MiB 尝试: 0 已通过: 0 难度: (无) 上传者: 标签>动态规划dp2009NOI 系列区间 dpTreap

[NOI2009] 二叉查找树

题目描述

已知一棵特殊的二叉查找树。根据定义,该二叉查找树中每个结点的数据值都比它左儿子结点的数据值大,而比它右儿子结点的数据值小。

另一方面,这棵查找树中每个结点都有一个权值,每个结点的权值都比它的儿子结点的权值要小。

已知树中所有结点的数据值各不相同;所有结点的权值也各不相同。这时可得出这样一个有趣的结论:如果能够确定树中每个结点的数据值和权值,那么树的形态便可以唯一确定。因为这样的一棵树可以看成是按照权值从小到大顺序插入结点所得到的、按照数据值排序的二叉查找树。

一个结点在树中的深度定义为它到树根的距离加 11。因此树的根结点的深度为 11

每个结点除了数据值和权值以外,还有一个访问频度。我们定义一个结点在树中的访问代价为它的访问频度乘以它在树中的深度。整棵树的访问代价定义为所有结点在树中的访问代价之和。

现在给定每个结点的数据值、权值和访问频度,你可以根据需要修改某些结点的权值,但每次修改你会付出 KK 的额外修改代价。你可以把结点的权值改为任何实数,但是修改后所有结点的权值必须仍保持互不相同。现在你要解决的问题是,整棵树的访问代价与额外修改代价的和最小是多少?

输入格式

输入文件中的第一行为两个正整数 N,KN,K。其中 NN 表示结点的个数,KK 表示每次修改所需的额外修改代价。

接下来的一行为 NN 个非负整数,表示每个结点的数据值。

再接下来的一行为 NN 个非负整数,表示每个结点的权值。

再接下来的一行为 NN 个非负整数,表示每个结点的访问频度。

其中:所有的数据值、权值、访问频度均不超过 4×1054 \times 10^5

输出格式

输出文件中仅一行为一个数,即你所能得到的整棵树的访问代价与额外修改代价之和的最小值。

4 10
1 2 3 4
1 2 3 4
1 2 3 4

29

提示

样例解释

输入的原图是左图,它的访问代价是 1×1+2×2+3×3+4×4=301 \times 1+2 \times 2+3 \times 3+4 \times 4=30

最佳的修改方案是把输入中的第 33 个结点的权值改成 00,得到右图,访问代价是:1×2+2×3+3×1+4×2=191 \times 2+2 \times 3+3 \times 1+4 \times 2=19,加上额外修改代价 1010,一共是 2929

数据范围

  • 对于 40%40\% 的数据,满足 N30N \leq 30
  • 对于 70%70\% 的数据,满足 N50N \leq 50
  • 对于 100%100\% 的数据,满足:1N701 \leq N \leq 701K3×1071 \leq K \leq 3 \times 10^7