6130: Greg and Array

内存限制:256 MB 时间限制:2 S 标准输入输出
题目类型:传统 评测方式:文本比较 上传者:
提交:0 通过:0

题目描述

time limit per test
1.5 seconds
memory limit per test
256 megabytes
input
standard input
output
standard output

Greg has an array a=a1,a2,...,an and m operations. Each operation looks as: li, ri, di, (1≤lirin). To apply operation i to the array means to increase all array elements with numbers li,li+1,...,ri by value di.

Greg wrote down k queries on a piece of paper. Each query has the following form: xi, yi, (1≤xiyim). That means that one should apply operations with numbers xi,xi+1,...,yi to the array.

Now Greg is wondering, what the array a will be after all the queries are executed. Help Greg.

Input

The first line contains integers n, m, k (1≤n,m,k≤105). The second line contains n integers: a1,a2,...,an (0≤ai≤105) − the initial array.

Next m lines contain operations, the operation number i is written as three integers: li, ri, di, (1≤lirin), (0≤di≤105).

Next k lines contain the queries, the query number i is written as two integers: xi, yi, (1≤xiyim).

The numbers in the lines are separated by single spaces.

Output

On a single line print n integers a1,a2,...,an − the array after executing all the queries. Separate the printed numbers by spaces.

Please, do not use the %lld specifier to read or write 64-bit integers in C++. It is preferred to use the cin, cout streams of the %I64d specifier.

Examples
Input
3 3 3
1 2 3
1 2 1
1 3 2
2 3 4
1 2
1 3
2 3
Output
9 18 17
Input
1 1 1
1
1 1 1
1 1
Output
2
Input
4 3 6
1 2 3 4
1 2 1
2 3 2
3 4 4
1 2
1 3
2 3
1 2
1 3
2 3
Output
5 18 31 20