#USUBQSUB. Update Sub-Matrix & Query Sub-Matrix
Update Sub-Matrix & Query Sub-Matrix
Updating and querying 1 dimensional arrays is a popular question. How about updating and quering sub-matrices of a matrix?
A sub-matrix will be depicted as (a, b), (c, d). This implies that it will include all the cells (x, y) such that a<=x<=c and b<=y<=d.
The matrix is indexed from [1..N][1..N], where N is the size.
You are given a matrix of size NxN, with each element initially set to 0. There are M queries and each query can be of one of the two types:
1 x1 y1 x2 y2: This query asks you to return the sum of all the elements in the sub-matrix (x1, y1), (x2, y2).
2 x1 y1 x2 y2 K: This query asks you to add K to each element in the sub-matrix (x1, y1), (x2, y2).
Input
The first line of input contains N, M.
The next M lines contain queries in the same forms as stated above.
You may assume that x1<=x2 and y1<=y2 for all queries.
Also N<=1000 and M<=105. K<=109
Output
The answer to all the queries wherein you need to return the sum of elements in the sub-matrix, i.e., all the queries of type 1.
Sample Test Case
Input: 5 5
2 2 2 4 4 4
1 1 1 3 3
2 5 5 5 5 3
1 1 1 1 2
1 2 2 5 3
Output: 16
0
24
Note: Please be careful with certain languages as the output may exceed the range of the data type used to store it.
Please use 64-bit integers to store the results. For example, long long in C/C++.