codeforces#P1715C. Monoblock
Monoblock
Description
Stanley has decided to buy a new desktop PC made by the company "Monoblock", and to solve captcha on their website, he needs to solve the following task.
The awesomeness of an array is the minimum number of blocks of consecutive identical numbers in which the array could be split. For example, the awesomeness of an array
- $[1, 1, 1]$ is $1$;
- $[5, 7]$ is $2$, as it could be split into blocks $[5]$ and $[7]$;
- $[1, 7, 7, 7, 7, 7, 7, 7, 9, 9, 9, 9, 9, 9, 9, 9, 9]$ is 3, as it could be split into blocks $[1]$, $[7, 7, 7, 7, 7, 7, 7]$, and $[9, 9, 9, 9, 9, 9, 9, 9, 9]$.
You are given an array $a$ of length $n$. There are $m$ queries of two integers $i$, $x$. A query $i$, $x$ means that from now on the $i$-th element of the array $a$ is equal to $x$.
After each query print the sum of awesomeness values among all subsegments of array $a$. In other words, after each query you need to calculate $$\sum\limits_{l = 1}^n \sum\limits_{r = l}^n g(l, r),$$ where $g(l, r)$ is the awesomeness of the array $b = [a_l, a_{l + 1}, \ldots, a_r]$.
In the first line you are given with two integers $n$ and $m$ ($1 \leq n, m \leq 10^5$).
The second line contains $n$ integers $a_1, a_2, \ldots, a_n$ ($1 \le a_i \le 10^9$) — the array $a$.
In the next $m$ lines you are given the descriptions of queries. Each line contains two integers $i$ and $x$ ($1 \leq i \leq n$, $1 \leq x \leq 10^9$).
Print the answer to each query on a new line.
Input
In the first line you are given with two integers $n$ and $m$ ($1 \leq n, m \leq 10^5$).
The second line contains $n$ integers $a_1, a_2, \ldots, a_n$ ($1 \le a_i \le 10^9$) — the array $a$.
In the next $m$ lines you are given the descriptions of queries. Each line contains two integers $i$ and $x$ ($1 \leq i \leq n$, $1 \leq x \leq 10^9$).
Output
Print the answer to each query on a new line.
Samples
5 5
1 2 3 4 5
3 2
4 2
3 1
2 1
2 2
29
23
35
25
35
Note
After the first query $a$ is equal to $[1, 2, 2, 4, 5]$, and the answer is $29$ because we can split each of the subsegments the following way:
- $[1; 1]$: $[1]$, 1 block;
- $[1; 2]$: $[1] + [2]$, 2 blocks;
- $[1; 3]$: $[1] + [2, 2]$, 2 blocks;
- $[1; 4]$: $[1] + [2, 2] + [4]$, 3 blocks;
- $[1; 5]$: $[1] + [2, 2] + [4] + [5]$, 4 blocks;
- $[2; 2]$: $[2]$, 1 block;
- $[2; 3]$: $[2, 2]$, 1 block;
- $[2; 4]$: $[2, 2] + [4]$, 2 blocks;
- $[2; 5]$: $[2, 2] + [4] + [5]$, 3 blocks;
- $[3; 3]$: $[2]$, 1 block;
- $[3; 4]$: $[2] + [4]$, 2 blocks;
- $[3; 5]$: $[2] + [4] + [5]$, 3 blocks;
- $[4; 4]$: $[4]$, 1 block;
- $[4; 5]$: $[4] + [5]$, 2 blocks;
- $[5; 5]$: $[5]$, 1 block;