#P51466. [USACO 2021 US Open Platinum] United Cows of Farmer John

[USACO 2021 US Open Platinum] United Cows of Farmer John

Description

The United Cows of Farmer John (UCFJ) are sending a delegation to the International bOvine olympIad (IOI). There are N cows participating in delegation selection (1N21051 \leq N \leq 2⋅10^5). They are standing in a line, and cow i has breed bi.

The delegation will consist of a contiguous interval of at least three cows - that is, cows lrl…r for integers l and r satisfying 1l<rN1 \leq l < r \leq N and rl2r − l \geq 2. Three of the cows in the chosen interval are marked as delegation leaders. For legal reasons, the two outermost cows of the chosen interval must be leaders. Moreover, to avoid intra-breed conflict, every leader must be of a different breed from the rest of the delegation (leaders or not).

Help the UCFJ determine (for tax reasons) the number of ways they might choose a delegation to send to the IOI. Two delegations are considered different if they have different members or different leaders.

Input

The first line contains NN.

The second line contains NN integers b1,b2,,bNb_1, b_2, \ldots , b_N, each in the range [1,N][1,N].

Output

The number of possible delegations, on a single line.

Note that the large size of integers involved in this problem may require the use of 64-bit integer data types (e.g., a "long long" in C/C++).

Sample

7
1 2 3 4 3 2 5
9

Each delegation corresponds to one of the following triples of leaders:

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

Scoring

  • Test cases 1-2 satisfy N50N≤50.
  • Test cases 3-4 satisfy N500N≤500.
  • Test cases 5-8 satisfy N5000N≤5000.
  • Test cases 9-20 satisfy no additional constraints.

Problem credits: Benjamin Qi