Write a program which manipulates a sequence A = {a0,a1,...,an−1} with the following operations:
Note that the initial values of ai(i=0,1,...,n−1) are 0.
n q query1 query2 : queryq
In the first line, n (the number of elements in A) and q (the number of queries) are given. Then, ith query queryi is given in the following format:
0 s t x
or
1 s t
The first digit represents the type of the query. '0' denotes add(s,t,x) and '1' denotes find(s,t).
For each find query, print the minimum value.
6 7 0 1 3 1 0 2 4 -2 1 0 5 1 0 1 0 3 5 3 1 3 4 1 0 5
-2 0 1 -1