loj#P2509. 「AHOI / HNOI2018」排列

「AHOI / HNOI2018」排列

题目描述

给定 nn 个整数 a1,a2,,an(0ain)a_1, a_2, \ldots , a_n(0 \le a_i \le n),以及 nn 个整数 w1,w2,,wnw_1, w_2, …, w_n。称 a1,a2,,ana_1, a_2, \ldots , a_n 的一个排列 ap[1],ap[2],,ap[n]a_{p[1]}, a_{p[2]}, \ldots , a_{p[n]}a1,a2,,ana_1, a_2, \ldots , a_n 的一个合法排列,当且仅当该排列满足:对于任意的 kk 和任意的 jj,如果 jkj \le k,那么 ap[j]a_{p[j]} 不等于 p[k]p[k]。(换句话说就是:对于任意的 kk 和任意的 jj,如果 p[k]p[k] 等于 ap[j]a_{p[j]},那么 k<jk<j。)

定义这个合法排列的权值为 wp[1]+2wp[2]++nwp[n]w_{p[1]} + 2w_{p[2]} + \ldots + nw_{p[n]}。你需要求出在所有合法排列中的最大权值。如果不存在合法排列,输出 1-1

样例解释中给出了合法排列和非法排列的实例。

输入格式

第一行一个整数 nn

接下来一行 nn 个整数,表示 a1,a2,,ana_1,a_2,\ldots , a_n

接下来一行 nn 个整数,表示 w1,w2,,wnw_1,w_2,\ldots ,w_n

输出格式

输出一个整数表示答案。

3
0 1 1
5 7 3
32
3
2 3 1
1 2 3
-1
10
6 6 10 1 7 0 0 1 7 7
16 3 10 20 5 14 17 17 16 13
809

数据范围与提示

对于前 20%20\% 的数据,1n101 \le n \le 10

对于前 40%40\% 的数据,1n151 \le n \le 15

对于前 60%60\% 的数据,1n10001 \le n \le 1000

对于前 80%80\% 的数据,1n1000001 \le n \le 100000

对于 100%100\% 的数据,1n5000001 \le n \le 5000000ain(1in)0 \le a_i \le n (1 \le i \le n)1wi1091 \le w_i \le 10^9 ,所有 wiw_i 的和不超过 1.5×10131.5 \times 10^{13}