#P6040. 「ACOI2020」课后期末考试滑溜滑溜补习班

    ID: 4572 Type: RemoteJudge 1000ms 256MiB Tried: 0 Accepted: 0 Difficulty: 4 Uploaded By: Tags>动态规划,dp2020单调队列O2优化动态规划优化

「ACOI2020」课后期末考试滑溜滑溜补习班

题目背景

T2

潮田 渚(Shiota Nagisa)因为理科不大好,自然会被仔细观察学生的杀老师发现,于是渚同学只得加入杀老师举办的课后期末考试滑溜滑溜补习班。至于为什么叫这个名字,额,你不能问我啊。

题目描述

在补习班上,因为多个学生会同时有需求,所以杀老师会制造分身用音速移动来回回答问题。

补习班上有 nn 个同学,他们每一个人都有一个问题。杀老师为了有序回答学生的问题,把所有学生排成了一列。第 ii 个学生的问题有一个困难值 aia_i,杀老师回答第 ii 个学生的问题需要花费 aia_i 的精力。杀老师到了哪里,它就要解决那个学生的问题。杀老师最开始会解决序列中第一个同学的问题,他最后会去解决最后一个同学的问题。

杀老师每次解决完一个同学的问题到下一个同学的座位上就要花费 kk 点精力值。特殊的,如果杀老师想让自己轻松一点,可以不移动到下一个,可以直接到下两个,下三个,就不用解决跳过的同学的问题了。对应的,它会被学生调侃。受到打击的杀老师自然会花费格外的精力,花费的精力为 k+(qp1)×dk+(q-p-1) \times d(当前位置为 pp,跳到的位置为 qq)。

当然的,杀老师也是有速度的啊,并且它想解决学生的一些问题,所以说杀老师最多只会跳过 x1x-1 个学生,去解决下 xx 个学生的问题。

输入格式

第一行五个整数 n,k,d,x,tpn,k,d,x,tp,表示有 nn 个学生,只按顺序去到下一个学生的座位需要花费 kk 点精力,每多跳过一个学生就要多花费 dd 点精力值,每一次最多只能跳过 x1x-1 个学生,是否是特殊数据。

  • tp=0tp=0,第二行 nn 个整数 a1na_{1\dots n}aia_i 表示第 ii 个学生的问题的困难值为 aia_i

  • tp=1tp=1,第二行一个整数 SeedSeed,作为种子,然后调用 rndrnd 函数依次生成 nn 个整数,作为 aa 数组,aia_i 表示第 ii 个学生的问题的困难值为 aia_i

inline int rnd () {
	static const int MOD = 1e9;
	return Seed = ( 1LL * Seed * 0x66CCFF % MOD + 20120712 ) % MOD;
}

输出格式

一行一个整数,表示杀老师解决完最后一个同学的问题最少需要花费多少精力。

5 3 4 1 0
1 2 3 4 5

27
10 30630 56910 2 0
7484 99194 86969 17540 29184 68691 91892 81564 93999 74280 

717318
10000000 899999999 923456655 213111 1
1314520
9231813656566921

提示

样例解释 #1

杀老师每次不能跳过学生,因此他必须依次移动并解决所有问题,故答案为解决问题所需的精力 1+2+3+4+5=151+2+3+4+5=15 与移动所需的精力 4×3=124 \times 3=12,所以花费精力之和为 2727


数据范围

本题采用捆绑测试

  • Subtask 1(20 points),学生们学习认真听话,留下来的同学也会更少:tp=0tp=0n103n \leq 10^3
  • Subtask 2(30 points),杀老师的速度快极了,并且学生们没时间吐槽它:tp=0tp=0n106n \leq 10^6
  • Subtask 3(50 points),tp=1tp=1,其余无特殊限制。

对于 100%100\% 的数据,1n1071 \leq n \leq 10^70k,d,ai1090 \leq k,d,a_i \leq 10^91xn11 \leq x \leq n-1


提示

对于 tp=1tp=1 的数据,rndrnd 函数只用于减小输入量,标准算法不依赖该数据生成方式。