#LQ1566. 跳石头

跳石头

问题描述

小明正在和朋友们玩跳石头的小游戏,一共有 nn 块石头按 11nn 顺序排成一排,第 ii 块石头上写有正整数权值 cic_i

如果某一时刻小明在第 jj 块石头,那么他可以选择跳向第 j+cjj+c_j​ 块石头 (前提 j+cjnj+c_j≤n)或者跳向第 2j2j 块石头(前提 2jn2j≤n),没有可跳跃的目标时游戏结束。

假如小明选择从第 xx 块石头开始跳跃,如果某块石头有可能被小明经过 (“经过”指存在某一时刻小明在这个石头处),则将这块石头的权值纳入得分集合 SxS_x,那么小明从第 xx 块石头开始跳跃的得分为 Sx|S_x|

比如如果小明从第 xx 块石头出发,所有可能经过的石头上的权值分别为 5,3,5,2,3,那么 Sx=5,3,2S_x=5,3,2 得分为 Sx=3|S_x|=3。小明可以任选一块石头开始跳跃,请求出小明最多能获得的分数。

输入格式

输入共 22 行。

第一行为一个正整数 nn

第二行为 nn 个由空格分开的正整数 c1,c2,,cnc_1,c_2,…,c_n

输出格式

输出共 11 行,一个整数表示答案。

5
4 3 5 2 1
4

样例说明

从第一块石头出发得分最多,路径有以下几种:

  1. 115→5 号:选择从 11 号跳到 1+c1=51+c_1=5 号。
  2. 112→25→5 号:第一次选择从 11 号跳到 2×1=22×1=2 号,第二次选择从 22 号跳到 2+c2=52+c_2=5 号。
  3. 112→24→4 号:第一次选择从 11 号跳到 2×1=22×1=2 号,第二次选择从 22 号跳到 2×2=42×2=4

所以所有可能经过的石头的权值的集合为 S1={c1,c2,c4,c5}={4,3,2,1}S_1=\{c_1,c_2,c_4,c_5\}=\{4,3,2,1\},得分为 S1=4|S_1|=4

评测用例规模与约定

对于 20%20\% 的评测用例,保证 n20n≤20

对于 100%100\% 的评测用例,保证 n40000,cinn≤40000,c_i≤n