P10342 [THUSC 2019] 数列
题目描述
定义一个长度为 $k$ 的数列的价值为:$val = \max \limits_{1 \le i \le k}\{i \times f(i,k)\}$。
其中 $f(i,j)$ 表示区间 $[i,j]$ 范围内数值种类数。
给出一个长度为 $n$ 的数列,计算所有连续子区间的价值总和。将一个连续子区间视为一个独立的数列,计算出的价值即为该连续子区间的价值。
设 $m$ 为数列里出现的数值种类数。
输入格式
第一行输入一个整数 $n$。
第二行输入 $n$ 个正整数,$a_1, a_2, \dots, a_n$ 描述数列里每个位置上的数值。
对于所有的输入数据,都满足 $1\le n \le 10^5$。
输出格式
第一行输出一个整数表示答案对 $998\ 244\ 353$ 取模。
说明/提示
**【样例解释 1】**
所有长度为 $1$ 的区间对答案的贡献都是 $1$。
所有长度为 $2$ 的区间对答案的贡献都是 $2$。
$[1,3]$ 这个区间对答案贡献为 $3$。
$[2,4]$ 这个区间对答案贡献为 $4$。
$[1,4]$ 这个区间对答案贡献为 $6$。
综上答案为 $ans = 4 \times 1 + 2 \times 3 + 3 + 4 + 6 = 23$。
**【样例 2】**
见题目附件 `2.in/ans`
**【样例 3】**
见题目附件 `3.in/ans`
**【样例 4】**
见题目附件 `4.in/ans`
**【样例 5】**
见题目附件 `5.in/ans`
**【子任务】**
| 子任务编号 | $n\le$ | $m\le$ | $a_i\le$ | 约束 | 分值 |
| :--: | :--: | :--: | :--: | :--: | :--: |
| 1 | $800$ | $800$ | $10^5$ | 无 | 13 |
| 2 | $10^5$ | $10^5$ | $10^5$ | 不会出现相同的数值 | 15 |
| 3 | $8\times 10^4$ | $600$ | $10^5$ | $[1,m][m+1,2m]\dots[\lfloor\frac{n}{m}\rfloor\times m + 1,n]$每个区间无重复数值 | 21 |
| 4 | $10^5$ | $80$ | $10^5$ | 无 | 24 |
| 5 | $8\times 10^4$ | $600$ | $10^5$| 无 | 27 |