시간 제한메모리 제한제출정답맞힌 사람정답 비율
3 초 1024 MB0000.000%

문제

Линн уже взрослая, скоро она пойдет в колледж. Но поступить туда не так просто. Она решила прорешивать задачи старых лет, чтобы лучше подготовиться.

Одним из заданий на вступительной олимпиаде прошлого года была следующая задача: дано дерево, в котором в $i$-й вершине записано число $a_i$. Все, что требовалось от участников олимпиады --- посчитать сумму $$\sum_{i=1}^n \sum_{j=i}^n (max(i \ldots j)-min(i \ldots j)) \cdot len(i \ldots j)$$

Здесь $max(i \ldots j)$ --- максимальное из значений $a_k$ для всех вершин $k$ на пути из $i$ в $j$, $min(i \ldots j)$ --- минимальное из тех же значений, $len(i \ldots j)$ --- число вершин на пути из $i$ в $j$.

Линн уже который час пытается решить эту задачу, но все безуспешно. Помогите ей!

입력

В первой строке входного файла записано целое число $n$ ($1 \le n \le 5 \cdot 10^4$) --- число вершин в дереве. Во второй строке заданы $n$ целых чисел $a_i$ ($0 \le a_i \le 10^5$) --- числа, записанные в вершинах. В следующих $n-1$ строках заданы пары целых чисел $u, v$ ($1 \le u, v \le n$) --- ребра дерева.

출력

В единственной строке выходного файла выведите значение искомой суммы.

예제 입력 1

5
1 2 3 4 5
1 2
2 3
3 4
4 5

예제 출력 1

70

예제 입력 2

4
0 1 1 1
1 2
1 3
1 4

예제 출력 2

15