CF1167F Scalar Queries

题目描述

给出一个数组$a_1,a_2,...,a_n$,其中所有元素两两不同。 定义函数$f(l,r)$: - 定义数组$b_1,b_2,...,b_{r-l+1}$,其中$b_i=a_{l-1+i}$ - 将$b$按从小到大排序 - 则此时函数的值是$\sum\limits_{i=1}^{r-l+1}{b_i}\cdot i$ 请计算对于所有满足$1 \le l \le r \le n$的$l$和$r$,$f(l,r)$的和。 由于结果可能很大,请输出对$10^9+7$取模的值。

输入格式

第一行包含一个整数$n$,即给定数组的长度。 第二行包含$n$个整数$a_1,a_2,...,a_n$,表示数组元素。

输出格式

输出一个整数,表示答案对$10^9+7$取模的值。

说明/提示

$1 \le n \le 5 \cdot 10^5$, $1 \le a_i \le 10^9$, 所有$a_i$两两不同。 样例1解释: $ f(1, 1) = 5 \cdot 1 = 5 $ ; $ f(1, 2) = 2 \cdot 1 + 5 \cdot 2 = 12 $ ; $ f(1, 3) = 2 \cdot 1 + 4 \cdot 2 + 5 \cdot 3 = 25 $ ; $ f(1, 4) = 2 \cdot 1 + 4 \cdot 2 + 5 \cdot 3 + 7 \cdot 4 = 53 $ ; $ f(2, 2) = 2 \cdot 1 = 2 $ ; $ f(2, 3) = 2 \cdot 1 + 4 \cdot 2 = 10 $ ; $ f(2, 4) = 2 \cdot 1 + 4 \cdot 2 + 7 \cdot 3 = 31 $ ; $ f(3, 3) = 4 \cdot 1 = 4 $ ; $ f(3, 4) = 4 \cdot 1 + 7 \cdot 2 = 18 $ ; $ f(4, 4) = 7 \cdot 1 = 7 $ ;