JZOJ1415. 单足跳(2017.8B组)

来源:互联网 发布:局域网禁用p2p软件 编辑:程序博客网 时间:2024/05/22 07:02

Description

  游戏在一行N个方块中进行,编号为1到N,一开始Alice在方块1中,第一次只能跳到方块2中,接下来每一次跳跃必须满足以下两个限制:
  (1) 如果是向前跳(即跳到比现在编号大的方块),跳跃距离必须比上一次要大1;
  (2) 如果是向后跳(即跳到比现在编号小的方块),跳跃距离必须跟上一次一样。
  例如,第一次跳跃后,Alice可以跳回1也可以跳到4。
  每进入一个方块,Alice必须支付一定的费用,Alice的目标花最少的钱从方块1跳到方块N。编程计算最小的花费。

Input

  第一行包含一个整数N(2<=N<=1000),表示方块的个数。
  接下来N行,每行包含一个不超过500的正整数表示进入该方块的费用。

Output

  输出Alice跳到N的最小花费。

Sample Input

输入1:
6
1
2
3
4
5
6

输入2:
8
2
3
4
3
1
6
1
4

Sample Output

输出1:
12

输出2:
14

Data Constraint
想法:
设f[i][j]为到第i个点,上一步跳跃距离为j的最小代价
f[i][j]=min(f[i-j-1][j-1],f[i+j][j])
因为要算j-1,j从小到大,因为要算i+j,i从大到小
然而我用spfa扫了一遍

原创粉丝点击