poj 2155:Matrix(二维线段树,矩阵取反,好题)
Time Limit: 3000MS | Memory Limit: 65536K | |
Total Submissions: 17880 | Accepted: 6709 |
Description
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 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
There is a blank line between every two continuous test cases.
Sample Input
1
2 10
C 2 1 2 2
Q 2 2
C 2 1 2 1
Q 1 1
C 1 1 2 1
C 1 2 1 2
C 1 1 2 2
Q 1 1
C 1 1 2 1
Q 2 1
Sample Output
1
0
0
1
Source

#include <iostream>
#include <stdio.h>
#include <string.h>
using namespace std; #define MAXN 1100 int tree[MAXN*][MAXN*],s; void Negate_y(int d,int dy,int L,int R,int y1,int y2) //取反操作
{
if(L==y1 && R==y2){ //将这个矩阵的所有元素记录为取反
tree[d][dy] = (tree[d][dy]+) % ;
return ;
} int mid = (L+R)>>;
if(mid>=y2)
Negate_y(d,dy<<,L,mid,y1,y2);
else if(mid<y1)
Negate_y(d,dy<<|,mid+,R,y1,y2);
else{
Negate_y(d,dy<<,L,mid,y1,mid);
Negate_y(d,dy<<|,mid+,R,mid+,y2);
}
} void Negate_x(int d,int L,int R,int x1,int y1,int x2,int y2) //取反操作
{
if(L==x1 && R==x2){ //找到行块
Negate_y(d,,,s,y1,y2);
return ;
} int mid = (L+R)>>;
if(mid>=x2)
Negate_x(d<<,L,mid,x1,y1,x2,y2);
else if(mid<x1)
Negate_x(d<<|,mid+,R,x1,y1,x2,y2);
else{
Negate_x(d<<,L,mid,x1,y1,mid,y2);
Negate_x(d<<|,mid+,R,mid+,y1,x2,y2);
}
} int Query_y(int d,int dy,int L,int R,int r) //查询
{
if(L==R) //找到要找的坐标,输出这个坐标对应的值
return tree[d][dy]; //没找到
int mid = (L+R)>>;
if(mid >= r)
return (Query_y(d,dy<<,L,mid,r)+tree[d][dy]) % ;
else
return (Query_y(d,dy<<|,mid+,R,r)+tree[d][dy]) % ;
} int Query_x(int d,int L,int R,int l,int r) //查询
{
if(L==R){ //找到要找的行块,继续查找列块
return Query_y(d,,,s,r);
} //没找到
int mid = (L+R)>>;
if(mid >= l)
return (Query_x(d<<,L,mid,l,r) + Query_y(d,,,s,r)) % ;
else
return (Query_x(d<<|,mid+,R,l,r) + Query_y(d,,,s,r)) % ;
} int main()
{
int X,T,x,y,x1,y1,x2,y2;
scanf("%d",&X);
while(X--){
memset(tree,,sizeof(tree));
scanf("%d%d",&s,&T);
while(T--){
char c[];
scanf("%s",c);
if(c[]=='C'){
scanf("%d%d%d%d",&x1,&y1,&x2,&y2);
Negate_x(,,s,x1,y1,x2,y2);
}
else if(c[]=='Q'){
scanf("%d%d",&x,&y);
printf("%d\n",Query_x(,,s,x,y));
}
}
if(X!=)
printf("\n");
} return ;
}
Freecode : www.cnblogs.com/yym2013
poj 2155:Matrix(二维线段树,矩阵取反,好题)的更多相关文章
- poj 2155 matrix 二维线段树 线段树套线段树
题意 一个$n*n$矩阵,初始全为0,每次翻转一个子矩阵,然后单点查找 题解 任意一种能维护二维平面的数据结构都可以 我这里写的是二维线段树,因为四分树的写法复杂度可能会退化,因此考虑用树套树实现二维 ...
- POJ 2155 Matrix (二维线段树入门,成段更新,单点查询 / 二维树状数组,区间更新,单点查询)
题意: 有一个n*n的矩阵,初始化全部为0.有2中操作: 1.给一个子矩阵,将这个子矩阵里面所有的0变成1,1变成0:2.询问某点的值 方法一:二维线段树 参考链接: http://blog.csdn ...
- poj 2155 matrix 二维线段树
题目链接 区间翻转, 单点查询, 查询操作我真是不太明白...... #include <iostream> #include <vector> #include <cs ...
- POJ2155 Matrix二维线段树经典题
题目链接 二维树状数组 #include<iostream> #include<math.h> #include<algorithm> #include<st ...
- POJ2155 Matrix 二维线段树
关键词:线段树 二维线段树维护一个 维护一个X线段的线段树,每个X节点维护一个 维护一个Y线段的线段树. 注意,以下代码没有PushDownX.因为如果要这么做,PushDownX时,由于当前X节点的 ...
- POJ 2155 Matrix(二维树状数组,绝对具体)
Matrix Time Limit: 3000MS Memory Limit: 65536K Total Submissions: 20599 Accepted: 7673 Descripti ...
- poj 2155 Matrix (二维树状数组)
题意:给你一个矩阵开始全是0,然后给你两种指令,第一种:C x1,y1,x2,y2 就是将左上角为x1,y1,右下角为x2,y2,的这个矩阵内的数字全部翻转,0变1,1变0 第二种:Q x1 y1,输 ...
- POJ 2155 Matrix(二维BIT)
Matrix [题目链接]Matrix [题目类型]二维BIT &题解: bit只能单点更新,恰好,这题可以想一下就可以用单点更新解决了. 只不过最后我交上去居然T了,想了10多分钟,试了一下 ...
- POJ 2019 Cornfields 二维线段树的初始化与最值查询
模板到不行.. 连更新都没有.. .存个模板. 理解留到小结的时候再写. #include <algorithm> #include <iostream> #include & ...
- CodeForces 242E二维线段树
E. XOR on Seg ...
随机推荐
- exit()和_exit()
进程就好比人一样有其生命,我们通过fork()函数来创建一个进程,那么我们又是如何来中止进程呢. 进程退出 1.在Linux中任何让一个进程退出 进程退出表示进程即将结束.在Linux中进程退出分为了 ...
- String和StringBuffer的转换
从String到StringBuffer: StringBuffer sb = New StringBuffer("abcd");从StringBuffer到String: Str ...
- ndk学习11: linux内存管理
1. 进程地址空间 2.内存管理 栈上分配空间 alloca() 栈上分配大小 strdupa() 拷贝一个字符串到栈上(显然这个函数不安全) ...
- jquery 打印宽高
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- 使用socket方式连接Nginx优化php-fpm性能
Nginx连接fastcgi的方式有2种:TCP和unix domain socket 什么是Unix domain socket?-- 维基百科 Unix domain socket 或者 IPC ...
- C# nullable<T> 用法小结
今天在园子里看到一个关于C#中对于可空类型的描述的帖子,感觉不错于是自己写了个小例子尝试下. 在C#中,对于可空类型描述为:Nullable<T>, 它表示该类型是可以为空的一个类型.它被 ...
- Walls and Gates
You are given a m x n 2D grid initialized with these three possible values. -1 - A wall or an obstac ...
- 使用jsvc启动tomcat
1.在/usr/local/apache-tomcat-7.0.68/bin中有commons-daemon-native.tar.gz 压缩包 2.解压commons-daemon-native. ...
- Java中时间日期格式化
1.与日期时间相关的类: 第一:java.util.Date; 将时间作为一个整体使用.处理时,使用Date类较为简便 第二:j ...
- pgpool介绍和安装经验
Pgpool的介绍 一.介绍 是一个工作在PostgreSQL多服务器和PostgreSQL数据库客户端之间的中间件. 二.概念图 三.功能 连接池:pgpool -Ⅱ保存 连 接到PostgreSQ ...