详细解释见小结。http://blog.csdn.net/zmx354/article/details/31740985

  1. #include <algorithm>
  2. #include <iostream>
  3. #include <cstring>
  4. #include <cstdlib>
  5. #include <cstdio>
  6. #include <queue>
  7. #include <cmath>
  8. #include <stack>
  9. #include <map>
  10.  
  11. #pragma comment(linker, "/STACK:1024000000");
  12. #define EPS (1e-8)
  13. #define LL long long
  14. #define ULL unsigned long long
  15. #define _LL __int64
  16. #define _INF 0x3f3f3f3f
  17. #define Mod 9999991
  18. #define lowbit(x) (x&(-x))
  19.  
  20. using namespace std;
  21.  
  22. const int N = 2049;
  23.  
  24. int a[N][N];
  25. int ax[N][N];
  26. int ay[N][N];
  27. int axy[N][N];
  28.  
  29. void Updata(int a[N][N],int x,int y,int n,int m,int data)
  30. {
  31. for(; x <= n; x += lowbit(x))
  32. {
  33. for(int t = y; t <= m; t += lowbit(t))
  34. {
  35. a[x][t] += data;
  36. }
  37. }
  38. }
  39.  
  40. int Query(int a[N][N],int x,int y)
  41. {
  42. int sum = 0;
  43.  
  44. while(x > 0)
  45. {
  46. for(int t = y; t > 0; t -= lowbit(t))
  47. {
  48. sum += a[x][t];
  49. }
  50. x -= lowbit(x);
  51. }
  52.  
  53. return sum;
  54. }
  55.  
  56. int sum(int x,int y)
  57. {
  58. return Query(a,x,y)*(x+1)*(y+1) - (y+1)*Query(ax,x,y) - (x+1)*Query(ay,x,y) + Query(axy,x,y);
  59. }
  60.  
  61. void Add(int x1,int y1,int x2,int y2,int n,int m,int data)
  62. {
  63. Updata(a,x1,y1,n,m,data);
  64. Updata(a,x2+1,y1,n,m,-data);
  65. Updata(a,x1,y2+1,n,m,-data);
  66. Updata(a,x2+1,y2+1,n,m,data);
  67.  
  68. Updata(ax,x1,y1,n,m,x1*data);
  69. Updata(ax,x2+1,y1,n,m,-(x2+1)*data);
  70. Updata(ax,x1,y2+1,n,m,-x1*data);
  71. Updata(ax,x2+1,y2+1,n,m,(x2+1)*data);
  72.  
  73. Updata(ay,x1,y1,n,m,y1*data);
  74. Updata(ay,x2+1,y1,n,m,-y1*data);
  75. Updata(ay,x1,y2+1,n,m,-(y2+1)*data);
  76. Updata(ay,x2+1,y2+1,n,m,(y2+1)*data);
  77.  
  78. Updata(axy,x1,y1,n,m,x1*y1*data);
  79. Updata(axy,x2+1,y1,n,m,-(x2+1)*y1*data);
  80. Updata(axy,x1,y2+1,n,m,-x1*(y2+1)*data);
  81. Updata(axy,x2+1,y2+1,n,m,(x2+1)*(y2+1)*data);
  82. }
  83.  
  84. int main()
  85. {
  86. int n,m;
  87.  
  88. char order[10];
  89.  
  90. int x1,x2,y1,y2,data;
  91.  
  92. memset(a,0,sizeof(a));
  93. memset(ax,0,sizeof(ax));
  94. memset(ay,0,sizeof(ay));
  95. memset(axy,0,sizeof(axy));
  96.  
  97. while(scanf("%s",order) != EOF)
  98. {
  99. if(order[0] == 'L')
  100. {
  101. scanf("%d %d %d %d %d",&x1,&y1,&x2,&y2,&data);
  102.  
  103. Add(x1,y1,x2,y2,n,m,data);
  104. }
  105. else if(order[0] == 'k')
  106. {
  107. scanf("%d %d %d %d",&x1,&y1,&x2,&y2);
  108.  
  109. printf("%d\n",sum(x2,y2) - sum(x1-1,y2) - sum(x2,y1-1) + sum(x1-1,y1-1));
  110. }
  111. else
  112. {
  113. scanf("%d %d",&n,&m);
  114. }
  115. }
  116.  
  117. return 0;
  118. }

二维树状数组的区间加减及查询 tyvj 1716 上帝造题的七分钟的更多相关文章

  1. POJ 2155 Matrix (二维线段树入门,成段更新,单点查询 / 二维树状数组,区间更新,单点查询)

    题意: 有一个n*n的矩阵,初始化全部为0.有2中操作: 1.给一个子矩阵,将这个子矩阵里面所有的0变成1,1变成0:2.询问某点的值 方法一:二维线段树 参考链接: http://blog.csdn ...

  2. POJ2155【二维树状数组,区间修改,点查询?】【又被输入输出坑】

    这题反反复复,到现在才过. 这道题就是树状数组的逆用,用于修改区间内容,查询点的值. 如果单纯就这个奇偶数来判的话,似乎这个思路比较好理解. 看了一下国家集训队论文(囧),<关于0与1在信息学奥 ...

  3. POJ2155 Matrix 【二维树状数组】+【段更新点查询】

    Matrix Time Limit: 3000MS   Memory Limit: 65536K Total Submissions: 17766   Accepted: 6674 Descripti ...

  4. 【bzoj5173】[Jsoi2014]矩形并 扫描线+二维树状数组区间修改区间查询

    题目描述 JYY有N个平面坐标系中的矩形.每一个矩形的底边都平行于X轴,侧边平行于Y轴.第i个矩形的左下角坐标为(Xi,Yi),底边长为Ai,侧边长为Bi.现在JYY打算从这N个矩形中,随机选出两个不 ...

  5. 牛客网 暑期ACM多校训练营(第二场)J.farm-STL(vector)+二维树状数组区间更新、单点查询 or 大暴力?

    开心.jpg J.farm 先解释一下题意,题意就是一个n*m的矩形区域,每个点代表一个植物,然后不同的植物对应不同的适合的肥料k,如果植物被撒上不适合的肥料就会死掉.然后题目将每个点适合的肥料种类( ...

  6. SCOI2014 bzoj3594 方伯伯的玉米田(二维树状数组+dp)

    3594: [Scoi2014]方伯伯的玉米田 Time Limit: 60 Sec  Memory Limit: 128 MBSubmit: 1971  Solved: 961[Submit][St ...

  7. 【poj2155】Matrix(二维树状数组区间更新+单点查询)

    Description Given an N*N matrix A, whose elements are either 0 or 1. A[i, j] means the number in the ...

  8. POJ 2155 Matrix【二维树状数组+YY(区间计数)】

    题目链接:http://poj.org/problem?id=2155 Matrix Time Limit: 3000MS   Memory Limit: 65536K Total Submissio ...

  9. POJ2155 Matrix(二维树状数组||区间修改单点查询)

    Given an N*N matrix A, whose elements are either 0 or 1. A[i, j] means the number in the i-th row an ...

随机推荐

  1. jdbc连接警告不安全

    Mon Jun 11 10:46:26 CST 2018 WARN: Establishing SSL connection without server's identity verificatio ...

  2. Python基础-列表、元祖

    1. 列表.元组操作 列表是我们最以后最常用的数据类型之一,通过列表可以对数据实现最方便的存储.修改等操作 定义列表 names = ['Alex',"Tenglan",'Eric ...

  3. poj 1329(已知三点求外接圆方程.)

    Circle Through Three Points Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 3766   Acce ...

  4. 系统封装的dispatch系列代码块引起的循环引用

    整整一天的时间都在找内存泄漏,唯独遗漏了这个代码块,结果就是它,希望大家以后注意. dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)( ...

  5. SQL 并发-转

    脏读.不可重复读  共享锁.悲观锁 和 事务五种隔离级别   一.脏读.不可重复读.幻读1.脏读:脏读就是指当一个事务正在访问数据,并且对数据进行了修改,而这种修改还没有提交到数据库中,这时,另外一个 ...

  6. Python的工具包[2] -> matplotlib图像绘制 -> matplotlib 库及使用总结

    matplotlib图像绘制 / matplotlib image description  目录 关于matplotlib matplotlib库 补充内容 Figure和AxesSubplot的生 ...

  7. 使用after伪类,配合IE的zoom或者overflow清除浮动

    用after伪类实现,兼容多种浏览器:.clearfix:after {content:"."; display:block; height:0; clear:both; visi ...

  8. Linux Whois命令安装与使用

    大家都知道查看域名的详细信息,都是跑去whois服务器去查询,如 http://whois.chinaz.com 其实在Linux下直接有一个whois的命令,不过需要安装jwhois才可以,以Cen ...

  9. ThinkPHP的自动验证常用的正则

    ThinkPHP的自动验证常用的正则   ThinkPHP的自动验证机制是为了进行表单数据验证,验证可以支持function. callback.confirm.equal.unique和regex, ...

  10. PHP添加mcrypt扩展模块

    PHP添加mcrypt扩展模块 系统环境:CentOS6.3 APACHE:httpd-2.4.2 PHP:php-5.3.21 一.安装mcrypt 1.下载Libmcrypt,mhash,mcry ...