A21231.小笼包
提高+/省选-
通过率:0%
时间限制:1.00s
内存限制:128MB
题目描述
JOI同学点的小笼包套餐,由馅料不同的N个小笼包组成。 N个小笼包等间隔排成一列,编号为1到N。第i个小笼包与第j个小笼包之间的距离是绝对值| i - j |。
JOI同学按照顺序吃小笼包。最初,所有的小笼包的美味度都是0。吃第i个小笼包时,汤汁向周围飞散,与第i个小笼包距离Di以下的小笼包都淋上了汤汁,而被淋上汤汁的小笼包的美味度会增加Ai。也就是说,吃第i个小笼包的时候,第j个小笼包 (1 ≦ j ≦ N 且 i - Di ≦ j ≦ i + Di)还没有吃到的话,第j个小笼包的美味度就增加Ai。
JOI 同学要在吃小笼包的顺序上下功夫,让吃的小笼包的美味度的合计最大化。
输入格式
输入共3行。
第1行是1个整数N。
第2行是N个整数D1, D2, ..., DN (0 ≦ Di ≦ 7) ,以空格分隔。
第3行是N个整数A1, A2, ..., AN (0 ≦ Ai ≦ 1000),以空格分隔。
输出格式
共1行,输出JOI同学吃的小笼包的美味度的合计最大值。
输入输出样例
输入#1
5 1 0 1 1 2 0 2 6 3 4
输出#1
20
输入#2
10 5 2 7 2 6 5 3 5 3 6 8 7 8 4 0 6 0 10 10 0
输出#2
237
说明/提示
样例1的说明:以第5→第3→第1→第2→第4的顺序吃的话,美味度合计为20,因为美味度超过20的吃法是不存在的,所以这是最好(坠吼)的。