time limit per test2 seconds

memory limit per test256 megabytes

inputstandard input

outputstandard output

Vasya commutes by train every day. There are n train stations in the city, and at the i-th station it’s possible to buy only tickets to stations from i + 1 to ai inclusive. No tickets are sold at the last station.

Let ρi, j be the minimum number of tickets one needs to buy in order to get from stations i to station j. As Vasya is fond of different useless statistic he asks you to compute the sum of all values ρi, j among all pairs 1 ≤ i < j ≤ n.

Input

The first line of the input contains a single integer n (2 ≤ n ≤ 100 000) — the number of stations.

The second line contains n - 1 integer ai (i + 1 ≤ ai ≤ n), the i-th of them means that at the i-th station one may buy tickets to each station from i + 1 to ai inclusive.

Output

Print the sum of ρi, j among all pairs of 1 ≤ i < j ≤ n.

Examples

input

4

4 4 4

output

6

input

5

2 3 5 5

output

17

Note

In the first sample it’s possible to get from any station to any other (with greater index) using only one ticket. The total number of pairs is 6, so the answer is also 6.

Consider the second sample:

ρ1, 2 = 1

ρ1, 3 = 2

ρ1, 4 = 3

ρ1, 5 = 3

ρ2, 3 = 1

ρ2, 4 = 2

ρ2, 5 = 2

ρ3, 4 = 1

ρ3, 5 = 1

ρ4, 5 = 1

Thus the answer equals 1 + 2 + 3 + 3 + 1 + 2 + 2 + 1 + 1 + 1 = 17.

【题解】



设dp[i]为i到i+1..n这些点的”总共”需要邮票的张数;

转移方程

dp[i] = dp[pos]+n-i-(a[i]-pos);

这里的pos,是(i+1..a[i])这个区间里面的a的值最大的下标;

表示的是从i开始往后转移的方式;

首先

从i->(i+1..a[i])都是只要一张票的。(这肯定是最优的)。所以不用从i到pos再转移到(pos+1..a[i]);

直接到pos+1..a[i]就可以了;

而a[i]之后的位置。则如果要到a[i]..a[pos]这段。则需要从i到pos再转移到。如下图。



上图中0->1、2、3、4、5、6这些都只要买一张票;

而dp[pos]包含了从pos->4、5的两张票;

如果再加上了dp[pos],则会重复;

因此要减去(a[i]-pos);

n-i+a[i]-pos

对应:

pos->a[i]后面的点;

然后从i连若干条边到pos;

因为有n-i+a[i]-pos个点。

所以总共要加n-i+a[i]-pos条边;

为什么选a最大的pos;

因为a[pos]是最大的。所以从pos可以走到更远的地方



如图,如果选择的是4。它最远能到8。则如果要到9就的再从8再买一张票到9;

而如果选择pos,则可以直接买一张票到9;这就节省了一张。

画图多理解下吧。

最后累加dp[1..n];

dp[n] = 0;

一开始dp[n-1]=1;

从n-2开始往前处理

获取某个区间内的最大值用ST算法就好(线段树is ok)

#include <cstdio>
#include <iostream>
#include <algorithm>
#include <cstring>
#include <queue>
#include <vector>
#include <stack>
#define LL long long using namespace std; const int MAXN = 200000;
const int MAX = 17; int n, a[MAXN],rmq[MAXN][MAX+3],pre[MAX+3];
int need[MAXN];
LL dp[MAXN],ans = 0; void input(int &r)
{
r = 0;
char t = getchar();
while (!isdigit(t)) t = getchar();
int sign = 1;
if (t == '-')sign = -1;
while (!isdigit(t)) t = getchar();
while (isdigit(t)) r = r * 10 + t - '0', t = getchar();
r = r*sign;
} int main()
{
//freopen("F:\\rush.txt", "r", stdin);
scanf("%d", &n);
for (int i = 1; i <= n-1; i++)
scanf("%d", &a[i]),rmq[i][0] = i; pre[0] = 1;
for (int i = 1; i <= MAX; i++)
pre[i] = pre[i - 1] * 2; int now = 1;
need[1] = 0;
for (int i = 2; i <= n; i++)
if (i == pre[now])
need[i] = need[i - 1] + 1,now++;
else
need[i] = need[i - 1]; for (int l = 1;pre[l]<=n;l++)
for (int i = 1; i + pre[l]-1<= n; i++)
{
int left = rmq[i][l-1];
int right = rmq[i + pre[l - 1]][l-1];
if (a[left] > a[right])
rmq[i][l] = left;
else
rmq[i][l] = right;
} dp[n-1] = 1;
ans = 1;
for (int i = n - 2; i >= 1; i--)
{
int xy = need[a[i] - i+1];
int left = rmq[i][xy], right = rmq[a[i] - pre[xy] + 1][xy];
int pos;
if (a[left] > a[right])
pos = left;
else
pos = right;
dp[i] = dp[pos] + n - i - (a[i] - pos);
ans += dp[i];
} printf("%I64d\n", ans);
return 0;
}

【34.54%】【codeforces 675E】Trains and Statistic的更多相关文章

  1. codeforces 675E E. Trains and Statistic(线段树+dp)

    题目链接: E. Trains and Statistic time limit per test 2 seconds memory limit per test 256 megabytes inpu ...

  2. 【 BowWow and the Timetable CodeForces - 1204A 】【思维】

    题目链接 可以发现 十进制4 对应 二进制100 十进制16 对应 二进制10000 十进制64 对应 二进制1000000 可以发现每多两个零,4的次幂就增加1. 用string读入题目给定的二进制 ...

  3. 【34.57%】【codeforces 557D】Vitaly and Cycle

    time limit per test1 second memory limit per test256 megabytes inputstandard input outputstandard ou ...

  4. 【24.34%】【codeforces 560D】Equivalent Strings

    time limit per test2 seconds memory limit per test256 megabytes inputstandard input outputstandard o ...

  5. 【34.88%】【codeforces 569C】Primes or Palindromes?

    time limit per test3 seconds memory limit per test256 megabytes inputstandard input outputstandard o ...

  6. 【中途相遇法】【STL】BAPC2014 K Key to Knowledge (Codeforces GYM 100526)

    题目链接: http://codeforces.com/gym/100526 http://acm.hunnu.edu.cn/online/?action=problem&type=show& ...

  7. 【codeforces 793D】Presents in Bankopolis

    [题目链接]:http://codeforces.com/contest/793/problem/D [题意] 给你n个点, 这n个点 从左到右1..n依序排; 然后给你m条有向边; 然后让你从中选出 ...

  8. 【codeforces 799D】Field expansion

    [题目链接]:http://codeforces.com/contest/799/problem/D [题意] 给你长方形的两条边h,w; 你每次可以从n个数字中选出一个数字x; 然后把h或w乘上x; ...

  9. 【22.73%】【codeforces 606D】Lazy Student

    time limit per test2 seconds memory limit per test256 megabytes inputstandard input outputstandard o ...

随机推荐

  1. Nginx 外的另一选择,轻量级开源 Web 服务器 Tengine 发布新版本

    新版发布 近日,轻量级开源 Web 服务器 Tengine 发布了2.3.0版本,新增如下特性: ngx_http_proxy_connect_module,该模块让 Tengine 可以用于正向代理 ...

  2. Introduction to 3D Game Programming with DirectX 12 学习笔记之 --- 第十二章:几何着色器(The Geometry Shader)

    原文:Introduction to 3D Game Programming with DirectX 12 学习笔记之 --- 第十二章:几何着色器(The Geometry Shader) 代码工 ...

  3. 通过JS操作CSS

    动态效果如图所示: 第一种实现方法: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" " ...

  4. Linux 中 grep 命令的 12 个实践例子

    2017-10-17 Linux小管家 你是否遇到过需要在文件中查找一个特定的字符串或者样式,但是不知道从哪儿开始?那么,就请grep来帮你吧. grep是每个Linux发行版都预装的一个强有力的文件 ...

  5. MySql计算两日期时间之间相差的天数,秒数,分钟数,周数,小时数

    MySql计算两日期时间之间相差的天数,秒数,分钟数,周数,小时数 计算两日期时间之间相差的天数,秒数,分钟数,周数,小时数,这里主要分享的是通过MySql内置的函数 TimeStampDiff() ...

  6. F4NNIU 的 Docker 学习资料整理

    F4NNIU 的 Docker 学习资料整理 Docker 介绍 以下来自 Wikipedia Docker是一个开放源代码软件项目,让应用程序部署在软件货柜下的工作可以自动化进行,借此在Linux操 ...

  7. This cache store does not support tagging.

    用户权限管理系统 https://github.com/Zizaco/entrust 再添加角色的时候... 报了一个错.. BadMethodCallException in Repository. ...

  8. Python collections的使用

    collections是Python内建的一个集合模块,提供了许多有用的集合类. 本文将介绍以下几种方法: namedtuple Counter() deque OrderedDict 一.named ...

  9. mysql 中 DATE_ADD(date,INTERVAL expr type)

    在Hiredmyway中: SELECT if(LENGTH(company_name) > 30,                   concat(SUBSTRING(company_nam ...

  10. HTML标题title滚动

    上代码: <script type="text/javascript"> var msg = document.title; msg = "…" + ...