Matrix
Time Limit: 3000MS   Memory Limit: 65536K
Total Submissions: 17880   Accepted: 6709

Description

Given an N*N matrix A, whose elements are either 0 or 1. A[i, j] means the number in the i-th row and j-th column. Initially we have A[i, j] = 0 (1 <= i, j <= N).

We can change the matrix in the following way. Given a rectangle whose upper-left corner is (x1, y1) and lower-right corner is (x2, y2), we change all the elements in the rectangle by using "not" operation (if it is a '0' then change it into '1' otherwise change it into '0'). To maintain the information of the matrix, you are asked to write a program to receive and execute two kinds of instructions.

1. C x1 y1 x2 y2 (1 <= x1 <= x2 <= n, 1 <= y1 <= y2 <= n) changes the matrix by using the rectangle whose upper-left corner is (x1, y1) and lower-right corner is (x2, y2). 
2. Q x y (1 <= x, y <= n) querys A[x, y]. 

Input

The first line of the input is an integer X (X <= 10) representing the number of test cases. The following X blocks each represents a test case.

The first line of each block contains two numbers N and T (2 <= N <= 1000, 1 <= T <= 50000) representing the size of the matrix and the number of the instructions. The following T lines each represents an instruction having the format "Q x y" or "C x1 y1 x2 y2", which has been described above.

Output

For each querying output one line, which has an integer representing A[x, y].

There is a blank line between every two continuous test cases.

Sample Input

  1. 1
  2. 2 10
  3. C 2 1 2 2
  4. Q 2 2
  5. C 2 1 2 1
  6. Q 1 1
  7. C 1 1 2 1
  8. C 1 2 1 2
  9. C 1 1 2 2
  10. Q 1 1
  11. C 1 1 2 1
  12. Q 2 1

Sample Output

  1. 1
  2. 0
  3. 0
  4. 1

Source

POJ Monthly,Lou Tiancheng

 
  二维线段树,矩阵取反,好题
 
  题意
  
  思路
  矩阵节点的值为是否取反,0为不取反,1为取反,暂称为取反值。
  取反操作的时候先找到这个矩阵代表的节点,然后将这个节点的值+1再模2,即取反。
  查询的时候,将(x,y)这个坐标经过的所有矩阵的取反值加起来,每次%2,最后那个值就为这个坐标最后的值。
  为什么%2,因为不是1就是0,矩阵记录了取反值,找这个坐标的过程中,经过的矩阵如果取反值为1,则结果变为0,在经过一个取反值为1的矩阵,结果又变为1…… 直到加到要找的坐标的取反值,这个结果记录的值就是这个坐标的取反值。这个时候输出结果。
 
  代码
  1. #include <iostream>
  2. #include <stdio.h>
  3. #include <string.h>
  4. using namespace std;
  5.  
  6. #define MAXN 1100
  7.  
  8. int tree[MAXN*][MAXN*],s;
  9.  
  10. void Negate_y(int d,int dy,int L,int R,int y1,int y2) //取反操作
  11. {
  12. if(L==y1 && R==y2){ //将这个矩阵的所有元素记录为取反
  13. tree[d][dy] = (tree[d][dy]+) % ;
  14. return ;
  15. }
  16.  
  17. int mid = (L+R)>>;
  18. if(mid>=y2)
  19. Negate_y(d,dy<<,L,mid,y1,y2);
  20. else if(mid<y1)
  21. Negate_y(d,dy<<|,mid+,R,y1,y2);
  22. else{
  23. Negate_y(d,dy<<,L,mid,y1,mid);
  24. Negate_y(d,dy<<|,mid+,R,mid+,y2);
  25. }
  26. }
  27.  
  28. void Negate_x(int d,int L,int R,int x1,int y1,int x2,int y2) //取反操作
  29. {
  30. if(L==x1 && R==x2){ //找到行块
  31. Negate_y(d,,,s,y1,y2);
  32. return ;
  33. }
  34.  
  35. int mid = (L+R)>>;
  36. if(mid>=x2)
  37. Negate_x(d<<,L,mid,x1,y1,x2,y2);
  38. else if(mid<x1)
  39. Negate_x(d<<|,mid+,R,x1,y1,x2,y2);
  40. else{
  41. Negate_x(d<<,L,mid,x1,y1,mid,y2);
  42. Negate_x(d<<|,mid+,R,mid+,y1,x2,y2);
  43. }
  44. }
  45.  
  46. int Query_y(int d,int dy,int L,int R,int r) //查询
  47. {
  48. if(L==R) //找到要找的坐标,输出这个坐标对应的值
  49. return tree[d][dy];
  50.  
  51. //没找到
  52. int mid = (L+R)>>;
  53. if(mid >= r)
  54. return (Query_y(d,dy<<,L,mid,r)+tree[d][dy]) % ;
  55. else
  56. return (Query_y(d,dy<<|,mid+,R,r)+tree[d][dy]) % ;
  57. }
  58.  
  59. int Query_x(int d,int L,int R,int l,int r) //查询
  60. {
  61. if(L==R){ //找到要找的行块,继续查找列块
  62. return Query_y(d,,,s,r);
  63. }
  64.  
  65. //没找到
  66. int mid = (L+R)>>;
  67. if(mid >= l)
  68. return (Query_x(d<<,L,mid,l,r) + Query_y(d,,,s,r)) % ;
  69. else
  70. return (Query_x(d<<|,mid+,R,l,r) + Query_y(d,,,s,r)) % ;
  71. }
  72.  
  73. int main()
  74. {
  75. int X,T,x,y,x1,y1,x2,y2;
  76. scanf("%d",&X);
  77. while(X--){
  78. memset(tree,,sizeof(tree));
  79. scanf("%d%d",&s,&T);
  80. while(T--){
  81. char c[];
  82. scanf("%s",c);
  83. if(c[]=='C'){
  84. scanf("%d%d%d%d",&x1,&y1,&x2,&y2);
  85. Negate_x(,,s,x1,y1,x2,y2);
  86. }
  87. else if(c[]=='Q'){
  88. scanf("%d%d",&x,&y);
  89. printf("%d\n",Query_x(,,s,x,y));
  90. }
  91. }
  92. if(X!=)
  93. printf("\n");
  94. }
  95.  
  96. return ;
  97. }

Freecode : www.cnblogs.com/yym2013

poj 2155:Matrix(二维线段树,矩阵取反,好题)的更多相关文章

  1. poj 2155 matrix 二维线段树 线段树套线段树

    题意 一个$n*n$矩阵,初始全为0,每次翻转一个子矩阵,然后单点查找 题解 任意一种能维护二维平面的数据结构都可以 我这里写的是二维线段树,因为四分树的写法复杂度可能会退化,因此考虑用树套树实现二维 ...

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

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

  3. poj 2155 matrix 二维线段树

    题目链接 区间翻转, 单点查询, 查询操作我真是不太明白...... #include <iostream> #include <vector> #include <cs ...

  4. POJ2155 Matrix二维线段树经典题

    题目链接 二维树状数组 #include<iostream> #include<math.h> #include<algorithm> #include<st ...

  5. POJ2155 Matrix 二维线段树

    关键词:线段树 二维线段树维护一个 维护一个X线段的线段树,每个X节点维护一个 维护一个Y线段的线段树. 注意,以下代码没有PushDownX.因为如果要这么做,PushDownX时,由于当前X节点的 ...

  6. POJ 2155 Matrix(二维树状数组,绝对具体)

    Matrix Time Limit: 3000MS   Memory Limit: 65536K Total Submissions: 20599   Accepted: 7673 Descripti ...

  7. poj 2155 Matrix (二维树状数组)

    题意:给你一个矩阵开始全是0,然后给你两种指令,第一种:C x1,y1,x2,y2 就是将左上角为x1,y1,右下角为x2,y2,的这个矩阵内的数字全部翻转,0变1,1变0 第二种:Q x1 y1,输 ...

  8. POJ 2155 Matrix(二维BIT)

    Matrix [题目链接]Matrix [题目类型]二维BIT &题解: bit只能单点更新,恰好,这题可以想一下就可以用单点更新解决了. 只不过最后我交上去居然T了,想了10多分钟,试了一下 ...

  9. POJ 2019 Cornfields 二维线段树的初始化与最值查询

    模板到不行.. 连更新都没有.. .存个模板. 理解留到小结的时候再写. #include <algorithm> #include <iostream> #include & ...

  10. CodeForces 242E二维线段树

                                                                                           E. XOR on Seg ...

随机推荐

  1. 14 BasicHashTable基本哈希表类(一)——Live555源码阅读(一)基本组件类

    这是Live555源码阅读的第一部分,包括了时间类,延时队列类,处理程序描述类,哈希表类这四个大类. 本文由乌合之众 lym瞎编,欢迎转载 http://www.cnblogs.com/oloroso ...

  2. PHP使用curl替代file_get_contents

    初学php的朋友们,很容易翻一个错误,在写采集程序或者调用api接口总会有线考虑到使用file_get_contents函数来或许内容,程序的访问量不大倒是没什么影响,但是访问量提升了那非常的悲剧了, ...

  3. lol 正在刷leetcode

    letcode easy 刷了90%了 我要写个随笔庆祝下 挑着做的太不要脸了,接下来要做剩下的了 :) 剩下的决定直接参考答案了 :) 有些答案看着也好迷糊.水平太差了.(英文水平差,看不懂题目.. ...

  4. MDI窗体

    1.设置父窗体 使用MDI窗体,需要先将父窗体的IsMdiContainer属性设置为True 2.生成用于MDI子窗体的窗体 1 frmTemp f1 = new frmTemp(); f1.Tex ...

  5. CEF3开发者系列之工程和代码结构

    CEF支持一系列的编程语言和操作系统,并且能很容易地整合到新的或已有的工程中去.它的设计思想就是易用且兼顾性能. CEF3支持一系列的编程语言和操作系统,并且能很容易地整合到新的或已有的工程中去.它的 ...

  6. windows8 安装TortoiseSVN后的反应

    因为工作需要,昨天安装了TortoiseSVN 64位版,没有马上重启. 随后,IIS中打开页面后浏览器一片空白,没有网页,没有地址,什么都没有.这时还没想到可能是TortoiseSVN的问题.后来实 ...

  7. Effective C++ -----条款09:绝不在构造和析构过程中调用virtual函数

    在构造和析构期间不要调用virtual函数,因为这类调用从不下降至derived class(比起当前执行构造函数和析构函数的那层).

  8. 前端js模版 预编译工具Tmod js使用入门

    1. 安装node js , 2. 用 npm install -g tmodjs  命令安装tmod 3.了解参数配置 4.运行测试例子->命令窗切换到当前文档位置 --->执行tomd ...

  9. xcode报错,svn : is not a workingCopy

    解决方案: 1.点击对应的targets 2.选择build phases 3.在红框处有一个run script选项(截图中已经删除了.),点击下拉按钮,看看是否是与svn有关的东西, 如果是,删除 ...

  10. win7自动登录桌面

    control userpasswords2 在开始菜单中搜索“运行”,回车打开,或者Win+R打开运行窗口. 键入“control userpasswords2”或者“rundll32 netplw ...