【树转数组】poj1195

/*
二维的树状数组:
更新某个元素时:
NO.1:c[n1],c[n2],c[n3],....,c[nm];
其中n1 = i,n(i+1) = ni+lowbit(ni);
nm+lowbit(nm)的值应该大于元素个数N。
NO.2:sum(k)=c[n1]+c[n2]+...+c[nm];
其中nm=k,n(i-1)=ni-lowbit(ni);
n1-lowbit(n1)的值应该小于0
----------------------------------------------------------------------
用二维的c[i][j]存储长条的和。。。、
---------------------------------------
元素的值加一个数:
void update(int x, int y, int a)
{
    for(int i=x; i<=s; i+=lowbit(i))
    {
        for(int j=y; j<=s; j+=lowbit(j))
            c[i][j] += a;
    }
}
---------------------------------------------------
int sum(int x, int y)矩阵0到x和0到y的元素和
{
    int ret = 0;
    for(int i=x; i>0; i-=lowbit(i))
    {
        for(int j=y; j>0; j-=lowbit(j))
            ret += c[i][j];
    }
    return ret;
}
------------------------------------------------
*/
#include <iostream>
#include <cstdio>
#include <cstring>
#define INF 0x3f3f3f3f

using namespace std;

int op,s;
int x,y,a;
int l,b,r,t;
int c[1050][1050];

int lowbit(int x)
{
    return x & (-x);
}

void update(int x, int y, int a)
{
    for(int i=x; i<=s; i+=lowbit(i))
    {
        for(int j=y; j<=s; j+=lowbit(j))
            c[i][j] += a;
    }
}

int sum(int x, int y)
{
    int ret = 0;
    for(int i=x; i>0; i-=lowbit(i))
    {
        for(int j=y; j>0; j-=lowbit(j))
            ret += c[i][j];
    }
    return ret;
}

int main()
{
    //freopen("input.txt","r",stdin);
    while(1)
    {
        scanf("%d",&op);
        if(op == 0)
        {
            scanf("%d",&s);
            memset(c, 0, sizeof(c));
        }
        if(op == 1)
        {
            scanf("%d%d%d",&x,&y,&a);
            update(x+1, y+1, a);
        }
        if(op == 2)
        {
            scanf("%d%d%d%d",&l, &b,&r,&t);
            l++;
            b++;
            r++;
            t++;
            printf("%d\n",sum(r, t) - sum(r, b-1) - sum(l-1, t) + sum(l-1, b-1) );
        }
        if(op == 3)
            return 0;
    }
}

----------------------------------

快。。。。。

【树转数组】poj1195

时间: 2024-07-30 13:42:56

【树转数组】poj1195的相关文章

POJ1195 Mobile phones 【二维树状数组】

Mobile phones Time Limit: 5000MS   Memory Limit: 65536K Total Submissions: 14288   Accepted: 6642 Description Suppose that the fourth generation mobile phone base stations in the Tampere area operate as follows. The area is divided into squares. The

POJ1195 Mobile phones 二维树状数组的应用

这题可以用线段树离散化做,用二维树状数组做了一下,不懂得可以看一下这篇文章:http://www.java3z.com/cwbwebhome/article/article1/1369.html?id=4804 题意: 给你一个s*s的正方形区域,先输入一个x,若x==0,则再输入一个s,若x==1,则输入x,y,a,表示矩阵中(x,y)这点的值加上a,若x==2,输入l,b,r,t,代表以左上角的点(l,b)右下角的点(r,t),求这一片矩形内的矩阵元素之和,若x==3则结束此次程序 就是最基

POJ-1195 Mobile phones---裸的二维树状数组(注意下标从1,1开始)

题目链接: https://vjudge.net/problem/POJ-1195 题目大意: 直接维护二维树状数组 注意横纵坐标全部需要加1,因为树状数组从(1,1)开始 1 #include<cstdio> 2 #include<cstring> 3 #include<iostream> 4 #include<algorithm> 5 #include<string> 6 #include<cmath> 7 #include<

poj1195(二维树状数组)

题目链接:https://vjudge.net/problem/POJ-1195 题意:有s*s的矩阵,初始化为全0,有两种操作,单点修改(x,y)的值,区间查询(x,y)的值(l<=x<=r,b<=y<=t). 思路:二维树状数组裸应用查询区间(l,b)~(r,t)的值可转换为tr[r][t]-tr[l-1][t]-tr[r][b-1]+tr[l-1][b-1].要注意的是输入的x,y是从0开始的,所以要加1. AC代码: #include<cstdio> #incl

POJ1195(二维树状数组)

Mobile phones Time Limit: 5000MS   Memory Limit: 65536K Total Submissions: 17176   Accepted: 7920 Description Suppose that the fourth generation mobile phone base stations in the Tampere area operate as follows. The area is divided into squares. The

POJ1195:Mobile phones(二维树状数组)

Description Suppose that the fourth generation mobile phone base stations in the Tampere area operate as follows. The area is divided into squares. The squares form an S * S matrix with the rows and columns numbered from 0 to S-1. Each square contain

二维树状数组(水题) POJ1195

前段时间遇到线段树过不了,树状数组却过了的题.(其实线段树过得了的) 回忆了下树状数组. 主要原理,还是二进制位数,每一项的和表示其为它的前((最后一位1及其后)的二进制数)和,可从二进制图来看.(用线段树想一想其实只是线段树编号不同而已,本质类似) 写了下二维树状数组,几乎和一维相同,也没必要不同. #include <cstdio> #include <cstring> int l,r,x,y,n,a,p,sum[1125][1125]; inline int lowbit(i

【POJ1195】【二维树状数组】Mobile phones

Description Suppose that the fourth generation mobile phone base stations in the Tampere area operate as follows. The area is divided into squares. The squares form an S * S matrix with the rows and columns numbered from 0 to S-1. Each square contain

POJ1195 Mobile phones【树状数组】【二维】

题目链接: http://poj.org/problem?id=1195 题目大意: 给出一个N*N的矩阵,初始化都为0,坐标从(0,0)开始.有三个操作: 命令1:1 x y w:将坐标为(x,y)处的点值增加w 命令2:2 x1 y1 x2 y2:询问左下角坐标为(x1,y1).右上角坐标为(x2,y2)的矩阵和是多少 命令3:3:不需要操作,退出. 思路: 二位树状数组单点更新,区间求值的简单题.直接做就可以了.最后求矩阵和的时候考虑容斥定理. 即ans = Query(x1-1,y1-1