CodeForces707E.Garlands(二维树状数组)

                                                               E. Garlands

time limit per test

3 seconds

memory limit per test

256 megabytes

input

standard input

output

standard output

Like all children, Alesha loves New Year celebration. During the celebration he and his whole family dress up the fir-tree. Like all children, Alesha likes to play with garlands — chains consisting of a lightbulbs.

Alesha uses a grid field sized n × m for playing. The rows of the field are numbered from 1 to n from the top to the bottom and columns are numbered from 1 to m from the left to the right.

Alesha has k garlands which he places at the field. He does so in the way such that each lightbulb of each garland lies in the center of some cell in the field, and each cell contains at most one lightbulb. Of course lightbulbs, which are neighbours in some garland, appears in cells neighbouring by a side.

CodeForces707E.Garlands(二维树状数组)_第1张图片

The example of garland placing.

Each garland is turned off or turned on at any moment. If some garland is turned on then each of its lightbulbs is turned on, the same applies for garland turned off. Each lightbulb in the whole garland set is unique, and thus, being turned on, brings Alesha some pleasure, described by an integer value. Turned off lightbulbs don't bring Alesha any pleasure.

Alesha can turn garlands on and off and wants to know the sum of pleasure value which the lightbulbs, placed in the centers of the cells in some rectangular part of the field, bring him. Initially all the garlands are turned on.

Alesha is still very little and can't add big numbers. He extremely asks you to help him.

Input

The first line of the input contains three integers nm and k (1 ≤ n, m, k ≤ 2000) — the number of field rows, the number of field columns and the number of garlands placed at the field respectively.

Next lines contains garlands set description in the following format:

The first line of a single garland description contains a single integer len (1 ≤ len ≤ 2000) — the number of lightbulbs in the garland.

Each of the next len lines contains three integers ij and w (1 ≤ i ≤ n, 1 ≤ j ≤ m, 1 ≤ w ≤ 109) — the coordinates of the cell containing a lightbullb and pleasure value Alesha gets from it if it is turned on. The lightbulbs are given in the order they are forming a chain in the garland. It is guaranteed that neighbouring lightbulbs are placed in the cells neighbouring by a side.

The next line contains single integer q (1 ≤ q ≤ 106) — the number of events in Alesha's game. The next q lines describes events in chronological order. The i-th of them describes the i-th event in the one of the following formats:

  • SWITCH i — Alesha turns off i-th garland if it is turned on, or turns it on if it is turned off. It is guaranteed that 1 ≤ i ≤ k.
  • ASK xyxy2 — Alesha wants to know the sum of pleasure values the lightbulbs, placed in a rectangular part of the field. Top-left cell of a part has coordinates (x1, y1) and right-bottom cell has coordinates (x2, y2). It is guaranteed that 1 ≤ x1 ≤ x2 ≤ n and 1 ≤ y1 ≤ y2 ≤ m. There is no more than 2000 events of this type in the input.

All the numbers in the input are integers.

Please note that the input is quite large, so be careful while using some input ways. In particular, it's not recommended to use cin in codes on C++ and class Scanner in codes on Java.

Output

For each ASK operation print the sum Alesha wants to know in a separate line. Print the answers in chronological order.

Examples

input

Copy

4 4 3
5
1 1 2
1 2 3
2 2 1
2 1 4
3 1 7
4
1 3 1
2 3 3
2 4 3
1 4 1
7
4 1 1
4 2 9
3 2 8
3 3 3
4 3 4
4 4 1
3 4 1
2
ASK 2 2 3 3
ASK 1 1 4 4

output

Copy

15
52

input

Copy

4 4 1
8
4 1 1
3 1 2
2 1 1
1 1 7
1 2 5
2 2 4
2 3 1
1 3 1
3
ASK 1 1 3 2
SWITCH 1
ASK 1 1 3 2

output

Copy

19
0

Note

CodeForces707E.Garlands(二维树状数组)_第2张图片

This image illustrates the first sample case.

 

一、原题地址

点我传送

 

二、大致题意

二维的矩阵,有k条链,每条链绑定着一些灯泡,每个灯泡亮着时有权值,灭掉的时候权值为0。一个链条控制其上所有灯泡的亮灭。

 

然后有q(<=106)q(<=106)个操作,分两种:

SWITCH i,按第i条链的开关,开变关,关变开

ASK x1,y1,x2,y2,查询以x1,y1为左上,x2,y2为右下的矩阵的权值,这个操作总数不超过2000。

 

三、大致思路

数据范围2000*2000,显然是二维的数状数组。

由于询问ASK只有2000次,所以考虑只在ASK时更新数组。那么就记录一下上一次询问时链条的亮灭情况,在考虑这一次需要增加和减少即可。

 

四、代码

#include
#include
#include
#include
#include
#include
#include
using namespace std;
typedef long long LL;
const int inf=0x3f3f3f3f;


int n,m,k;

const int N=2500+5;

LL c[N][N];
struct Node
{
    int len,x,y;
    LL w;
}Q[N][N];
int isOn[N*N],last[N*N];

void init()
{
    memset(c, 0, sizeof(c));
    for(int i=1;i<=n*n;i++)last[i]=isOn[i]=1;
}
inline int lowbit(int i)
{
    return i&(-i);
}
void add(int x, int y, LL val)
{
    for(int i = x; i <= n; i += lowbit(i))
    {
        for(int j = y; j <= m; j += lowbit(j))
        {
            c[i][j] += val;
        }
    }
}
LL sum(int x, int y)
{
    LL ans = 0;
    for(int i = x; i > 0; i -= lowbit(i))
        for(int j = y; j > 0; j -= lowbit(j))
            ans += c[i][j];
    return ans;
}
LL query(int x1, int y1, int x2, int y2)
{
    return sum(x2,y2) - sum(x2, y1-1) - sum(x1-1, y2) + sum(x1-1, y1-1);
}
//can't update (0,0)
//So need to add (0,0) to (1,1)



int main()
{
    scanf("%d %d %d",&n,&m,&k);
    init();
    for(int i=1;i<=k;i++)
    {
        scanf("%d",&Q[i][0].len);
        for(int j=1;j<=Q[i][0].len;j++)
        {
            scanf("%d %d %lld",&Q[i][j].x,&Q[i][j].y,&Q[i][j].w);
            add(Q[i][j].x,Q[i][j].y,Q[i][j].w);
        }
    }
    int qnum;
    scanf("%d",&qnum);
    char str[20];
    while(qnum--)
    {
        scanf("%s",str+1);
        if(str[1]=='A')
        {
            for(int i=1;i<=k;i++)
            {
                if(last[i]!=isOn[i])
                {
                    for(int j=1;j<=Q[i][0].len;j++)
                    {
                        if(isOn[i])add(Q[i][j].x,Q[i][j].y,Q[i][j].w);
                        else add(Q[i][j].x,Q[i][j].y,-Q[i][j].w);
                    }
                    last[i]=isOn[i];
                }
            }
            int x1,y1,x2,y2;
            scanf("%d %d %d %d",&x1,&y1,&x2,&y2);
            printf("%lld\n",query(x1,y1,x2,y2));
        }
        else
        {
            int ty;scanf("%d",&ty);
            isOn[ty]^=1;
        }


    }


}

 

 

你可能感兴趣的:(CodeForces707E.Garlands(二维树状数组))