bzoj#P1484. [HNOI2009]通往城堡之路

[HNOI2009]通往城堡之路

题目描述

听说公主被关押在城堡里,彭大侠下定决心:不管一路上有多少坎坷,不管城堡中的看守有多少厉害,不管救了公主之后公主会不会再被抓走,不管公主是否漂亮、是否会钟情于自己,他将义无反顾地朝着城堡前进。

可是,通往城堡的路上出现了一些情况。抽象地说,假象地图在二维平面的第一象限。在每个横轴的 xx 位置上有一个高为 hxh_x 的支撑点,如果彭大侠没有跳到支撑点上,那么他就会掉下去,牺牲在路途。开始时彭大侠在起点 (1,h1)(1,h_1) 处,而城堡的入口在 (n,hn)(n,h_n) 处。彭大侠每次可以从支撑点 (x,hx)(x,h_x) 跳到支撑点 (x+1,hx+1)(x+1,h_x+1)。但是彭大侠每次的跳跃能量只有 dd,也就是说,每次跳跃必须满足条件 hx+1hnd|h_x+1-h_n| \leq d。换句话说,如果两个相邻支撑点的纵向落差大于 dd,那么彭大侠就无法跳跃了!幸运的是,彭大侠还有一个杀手锏。在起点处,他可以花一个金币,把某个支撑点升高 11 个单位,或者降低 11 个单位。但是,起点处和城堡入口处的支撑点高度不能改变,并且一旦离开起点彭大侠就无法使用该杀手锏。

彭大侠被告知 100100 个金币可兑换一单位生命。于是他希望通过少花金币来保存更多单位的生命。他终于找到了你这位热心的高手,请你帮他规划一下以便耗费尽量少的金币来到达城堡。

输入格式

文件第一行包含一个整数 m (m5)m~(m \leq 5),表示问题求解次数。

接下来的 2×m2 \times m 行依次表示每次求解的输入数据块。每个输入数据块占 22 行。

其中第一行包含两个整数 nndd,分别表示从起点到城堡入口处必须经过的支撑点数和每次跳跃允许的最大纵向落差,nndd 之间用空格隔开,输入数据保证 2n5000, 0d1092 \leq n \leq 5000,~0 \leq d \leq 10^9

第二行包含用空格隔开的 nn 个非负整数 h1,h2hnh_1,h_2 \dots h_n,其中 hi (1in)h_i~(1 \leq i \leq n) 表示第 ii 个支撑点的高度,特别地,h1h_1 表示彭大侠出发时所在支撑点的高度,hnh_n 表示城堡入口所在支撑点的高度,输入数据保证对所有 1in1 \leq i \leq n0hi1090 \leq h_i \leq 10^9

输出格式

mm 行,第 I (1Im)I~(1 \leq I \leq m) 行表示第 II 次求解时彭大侠到达城堡必须耗费的最少金币数量。

若无论怎样使用杀手锏他都无法到达城堡,则输出 impossible

输入数据保证答案在 int64 范围之内。

3
10 2
4 5 10 6 6 9 4 7 9 8
3 1
6 4 0
4 2
3 0 6 3
6
impossible
4

样例解释

对样例中的第一个输入数据块,d=2d=2,把第三个支撑点降低 33 个单位,把第六个支撑点降低 11 个单位,把第七个支撑点升高 22 个单位,原序列变成:4 5 7 6 6 8 6 7 9 8\texttt{4 5 7 6 6 8 6 7 9 8},这时任意相邻支撑点的纵向落差没有超过 22,彭大侠可以到达城堡!

对样例中的第二个输入数据块,d=1d=1,这时不管怎样调节第二个支撑点的高度,都无法使任意相邻支撑点的纵向落差不超过 11

对样例中的第三个输入数据块,d=2d=2,这时,把第二个支撑点升高 11 个单位,把第三个支撑点降低 33 个单位就满足条件了。

数据范围

分值 范围
20% n≤100
40% n≤1000
100% n≤5000