A85859.「十二省联考 2019」春节十二响
省选/NOI-
通过率:0%
时间限制:1.00s
内存限制:512MB
题目描述
距离苏拉威西只有一百公里了,车内的空气比窗外更加冰冷。四双眼睛紧盯着艾莉芬面前的屏幕,那是控制行星发动机的关键程序:春节十二响。他需要将其部署到电力控制系统的一个芯片中。
「春节十二响」由 n 个子程序构成,第 i 个子程序所需的内存空间是 Mi。这 n 个子程序之间的调用关系构成了一棵以第 1 个子程序为根的树,其中第 i 个子程序在调用树上的父亲是第 fi 个子程序。
由于内存紧张,电力控制芯片上提供了一种内存分段机制。你可以将内存分为若干个段 S1,S2,…,Sk,并将每个程序预先分配到一个固定的段。如果两个子程序没有直接或间接的调用关系,则他们可以被分配到同一个段中,反之则不能。换言之,当且仅当 a 和 b 在调用树上不是祖先-后代关系,a 和 b 可以被分配到同一个段中。
一个段的大小应当是所有分配到这个段的子程序所需内存大小的最大值,所有段大小的和不能超过系统的内存大小。
现在艾莉芬想要知道,电力控制芯片至少要有多少内存,才能保证春节十二响的正确运行。即:最少需要多大的内存,才能通过先将内存分成若干个段,再把每个子程序分配到一个段中,使得每个段中分配的所有子程序之间不存在祖先-后代关系。
输入格式
从标准输入读入数据。
第一行包含一个正整数 n 表示子程序的个数,其中 n≤2×105。
第二行有 n 个用空格隔开的正整数 M1,M2,…,Mn,Mi 表示第 i 个子程序所需的内存空间。
第三行有 n−1 个用空格隔开的正整数 f2,f3,…,fn,满足 fi<i,表示第 i 个子程序在调用树上的父亲是第 fi 个子程序。
输出格式
输出到标准输出。
仅一个整数,表示最小的内存需求。
输入输出样例
输入#1
5 10 20 20 30 30 1 1 2 2
输出#1
60
说明/提示
| 测试点 | n | M | 是否是一条链 |
|---|---|---|---|
| 1∼2 | ≤5 | ≤10 | 否 |
| 3∼4 | ≤10 | ≤2 | 否 |
| 5∼9 | ≤16 | ≤109 | 否 |
| 10∼12 | ≤2×105 | ≤109 | 是 |
| 13∼15 | ≤2000 | ≤109 | 否 |
| 16∼20 | ≤2×105 | ≤109 | 否 |
注意:在第 10、11、12 号测试点中,1 号子程序不一定是链的一个端点。
其中 M 是所有子内存需求的最大值,即 max{Mi}。
对于全部数据,1≤n≤2×105,1≤M≤109。
提示
艾莉芬经过仔细阅读题面、认真分析数据范围后,开始编写程序求解这个问题。
$ login Elephant
password: ********
艾莉芬,高级程序员。豫阳市第三工程组提醒您:
- 做题千万条,读题第一条;
- 编程不规范,爆零两行泪。
$ cd spring
$ ac spring
Spring Accepted. Score: 100/100.