300911: CF174C. Range Increments

Memory Limit:256 MB Time Limit:2 S
Judge Style:Text Compare Creator:
Submit:0 Solved:0

Description

Range Increments

题意翻译

给出一个长度为 $n$ 的数组 $ a[1...\ n] $,给出一个全部为零的数组 $b$,可以将数组 $b$ 区间 $l$ 到 $r$ 之间的数全部加 $1$ ,问最少需要多少次操作使这两个数组完全相同,并输出方案。 如果有多种方案,输出其中的任意一种,保证总操作数小于 $10^{5}$。

题目描述

Polycarpus is an amateur programmer. Now he is analyzing a friend's program. He has already found there the function rangeIncrement(l, r), that adds 1 to each element of some array $ a $ for all indexes in the segment $ [l,r] $ . In other words, this function does the following: `<br></br>function rangeIncrement(l, r)<br></br> for i := l .. r do<br></br> a[i] = a[i] + 1<br></br>`Polycarpus knows the state of the array $ a $ after a series of function calls. He wants to determine the minimum number of function calls that lead to such state. In addition, he wants to find what function calls are needed in this case. It is guaranteed that the required number of calls does not exceed $ 10^{5} $ . Before calls of function rangeIncrement(l, r) all array elements equal zero.

输入输出格式

输入格式


The first input line contains a single integer $ n $ ( $ 1<=n<=10^{5} $ ) — the length of the array $ a[1...\ n] $ . The second line contains its integer space-separated elements, $ a[1],a[2],...,a[n] $ ( $ 0<=a[i]<=10^{5} $ ) after some series of function calls rangeIncrement(l, r). It is guaranteed that at least one element of the array is positive. It is guaranteed that the answer contains no more than $ 10^{5} $ calls of function rangeIncrement(l, r).

输出格式


Print on the first line $ t $ — the minimum number of calls of function rangeIncrement(l, r), that lead to the array from the input data. It is guaranteed that this number will turn out not more than $ 10^{5} $ . Then print $ t $ lines — the descriptions of function calls, one per line. Each line should contain two integers $ l_{i},r_{i} $ ( $ 1<=l_{i}<=r_{i}<=n $ ) — the arguments of the $ i $ -th call rangeIncrement(l, r). Calls can be applied in any order. If there are multiple solutions, you are allowed to print any of them.

输入输出样例

输入样例 #1

6
1 2 1 1 4 1

输出样例 #1

5
2 2
5 5
5 5
5 5
1 6

输入样例 #2

5
1 0 1 0 1

输出样例 #2

3
1 1
3 3
5 5

说明

The first sample requires a call for the entire array, and four additional calls: - one for the segment \[2,2\] (i.e. the second element of the array), - three for the segment \[5,5\] (i.e. the fifth element of the array).

Input

题意翻译

给出一个长度为 $n$ 的数组 $ a[1...\ n] $,给出一个全部为零的数组 $b$,可以将数组 $b$ 区间 $l$ 到 $r$ 之间的数全部加 $1$ ,问最少需要多少次操作使这两个数组完全相同,并输出方案。 如果有多种方案,输出其中的任意一种,保证总操作数小于 $10^{5}$。

加入题单

算法标签: