#P1651. Cow Frisbee

Cow Frisbee

题目描述

Farmer John 的 N (N3×105)N\ (N\le 3\times 10^5) 头奶牛的高度为 1,2,,N1, 2, \ldots, N。一天,奶牛以某个顺序排成一行玩飞盘;令 h1hNh_1 \ldots h_N 表示此顺序下奶牛们的高度(因此 hh1N1 \ldots N 的一个排列)。

队伍中位于位置 iijj 的两头奶牛可以成功地来回扔飞盘当且仅当她们之间的每头奶牛的高度都低于 min(hi,hj)\min(h_i, h_j)

请计算所有可以成功地来回扔飞盘的奶牛所在的位置对 iji\le j 之间的距离总和。位置 iijj 之间的距离为 ji+1j-i+1

输入格式

输入的第一行包含一个整数 NN。第二行包含 h1hNh_1 \ldots h_N,用空格分隔。

输出格式

输出可以成功地来回扔飞盘的奶牛所在的位置对 iji\le j 之间的距离总和。注意这个问题涉及到的整数可能需要使用 64 位整数型(例如,C 或 C++ 中的 "long long")。

样例 #1

样例输入 #1

7
4 3 1 2 5 6 7

样例输出 #1

24

提示

【样例解释】

这个例子中可以成功的位置对如下:

(1, 2), (1, 5), (2, 3), (2, 4), (2, 5), (3, 4), (4, 5), (5, 6), (6, 7)

【数据范围】

  • 测试点 1-3 满足 N5000N\le 5000
  • 测试点 4-11 没有额外限制。