POJ2155 Matrix二维线段树经典题
二维树状数组
#include<iostream> #include<math.h> #include<algorithm> #include<stdlib.h> using namespace std; #define ll long long #define re(i,n) for(int i=0;i<n;i++) ; int c[maxn][maxn]; int n, q; int lowbit(int x){ return x&(-x); } void update(int x, int y){ ; i-=lowbit(i)) ; j -= lowbit(j)) c[i][j] ^= ; } int query(int x, int y){ ; for (int i = x; i <= n; i+=lowbit(i)) for (int j = y; j <= n; j += lowbit(j)){ ans ^= c[i][j]; } return ans; } int main(){ //freopen("in.txt", "r", stdin); int T; cin >> T; while (T--){ scanf("%d%d", &n, &q); memset(c, , sizeof(c)); while (q--){ ]; scanf("%s", op); ] == 'Q'){ int x, y; scanf("%d%d", &x, &y); printf("%d\n", query(x, y)); } else{ int fx, fy, tx, ty; scanf("%d%d%d%d", &fx, &fy, &tx, &ty); if (fx > tx)swap(fx, tx); if (fy > ty)swap(fy, ty); fx--, fy--; update(fx, fy); update(tx, ty); update(fx, ty); update(tx, fy); } } puts(""); } ; }
二维线段树
#include<iostream> #include<stdio.h> #include<string.h> using namespace std; #define ll long long #define re(i,n) for(int i=0;i<n;i++) #define ls(x) x<<1,f,mid #define rs(x) x<<1|1,mid+1,t ; int n, q; int fx, fy, tx, ty, x, y; int ans; ][maxn << ]; void updatey(int i, int j, int f, int t){ if (fy <= f&&ty >= t){ a[i][j] ^= ; return; } ; if (fy <= mid)updatey(i,ls(j)); if (ty > mid)updatey(i, rs(j)); } void updatex(int i, int f, int t){ if (fx<=f&&tx>=t){ updatey(i, , , n); return; } ; if (fx <= mid)updatex(ls(i)); if (tx > mid)updatex(rs(i)); } void queryy(int i, int j, int f, int t){ ans += a[i][j]; if (f == t)return; ; if (y > mid)queryy(i,rs(j)); else queryy(i, ls(j)); } void queryx(int i, int f, int t){ queryy(i, , , n); if (f == t)return; ; if (x > mid)queryx(rs(i)); else queryx(ls(i)); } int main(){ //freopen("in.txt", "r", stdin); int T; cin >> T; while (T--){ scanf("%d%d", &n, &q); memset(a, , sizeof(a)); /*应该用memset,用for循环一定要注意初始化的不是n,而是全部. 公元2015年9.20日在于此坑. re(i, n + 1)re(j, n + 1)a[i][j] = 0; */ while (q--){ ]; scanf("%s", op); ] == 'Q'){ scanf("%d%d",&x,&y); ans = ; queryx(, , n); printf(); } else{ scanf("%d%d%d%d", &fx, &fy, &tx, &ty); if (fx > tx)swap(fx, tx); if (fy > ty)swap(fy, ty); updatex(,,n); //debug(); } } if (T)puts(""); } ; }
zkw二维线段树 开区间写法
#include<iostream> #include<stdio.h> #include<algorithm> using namespace std; ; typedef long long ll; #define re(i,n) for(int i=0;i<n;i++) ][maxn << ]; int n, q,sz; bool yquery(int x, int y){ y += sz; ; /* 因为1是哨兵节点,1必然始终都为0,不曾变化,所以算上1也无妨 */ while (y){ ans ^= tr[x][y]; y >>= ; } return ans; } bool query(int x,int y){ x += sz; ; while (x){ ans ^= yquery(x, y); x >>= ; } return ans; } void yupdate(int x, int fy, int ty){ fy += sz - , ty += sz + ; ){ )tr[x][fy ^ ] ^= ; )tr[x][ty ^ ] ^= ; fy >>= , ty >>= ; } } void update(int fx,int fy,int tx,int ty){ fx += sz - , tx += sz + ; ){ )yupdate(fx^, fy, ty); )yupdate(tx ^ , fy, ty); fx >>= , tx >>= ; } } int main(){ //freopen("in.txt", "r", stdin); int T; cin >> T; while (T--){ scanf("%d%d", &n, &q); sz = ; )sz <<= ; memset(tr, , sizeof(tr)); while (q--){ ]; scanf("%s", op); ] == 'Q'){ int x, y; scanf("%d%d", &x, &y); bool ans = query(x, y); printf("%d\n", ans); } else{ int fx, fy, tx, ty; scanf("%d%d%d%d", &fx, &fy, &tx, &ty); if (fx > tx)swap(fx, tx); if (fy > ty)swap(fy, ty); update(fx, fy, tx, ty); } } puts(""); } ; }
zwk二维线段树闭区间写法
#include<iostream> #include<stdio.h> #include<algorithm> using namespace std; ; typedef long long ll; #define re(i,n) for(int i=0;i<n;i++) ][maxn << ]; int n, q,sz; bool yquery(int x, int y){ y += sz-; ; /* 因为1是哨兵节点,1必然始终都为0,不曾变化,所以算上1也无妨 */ while (y){ ans ^= tr[x][y]; y >>= ; } return ans; } bool query(int x,int y){ x += sz-; ; while (x){ ans ^= yquery(x, y); x >>= ; } return ans; } /* 开区间=闭区间-两个端点. 所以,先处理两个端点之后就变成了开区间. 两个端点处理时要加上一个判断,l==r,如果相等,那就不能对同一个点处理两次,只处理一个点然后返回就行了;如果不等,那就先处理两端,再按照开区间的方式进行处理. */ void yupdate(int x, int fy, int ty){ fy += sz - , ty += sz -; ; return; } tr[x][fy] ^= , tr[x][ty] ^= ; ){ )tr[x][fy ^ ] ^= ; )tr[x][ty ^ ] ^= ; fy >>= , ty >>= ; } } void update(int fx,int fy,int tx,int ty){ fx += sz - , tx += sz - ; if (fx == tx){ yupdate(fx, fy, ty); return; } yupdate(fx, fy, ty), yupdate(tx, fy, ty); ){ )yupdate(fx^, fy, ty); )yupdate(tx ^ , fy, ty); fx >>= , tx >>= ; } } int main(){ freopen("in.txt", "r", stdin); int T; cin >> T; while (T--){ scanf("%d%d", &n, &q); sz = ; ; memset(tr, , sizeof(tr)); while (q--){ ]; scanf("%s", op); ] == 'Q'){ int x, y; scanf("%d%d", &x, &y); bool ans = query(x, y); printf("%d\n", ans); } else{ int fx, fy, tx, ty; scanf("%d%d%d%d", &fx, &fy, &tx, &ty); if (fx > tx)swap(fx, tx); if (fy > ty)swap(fy, ty); update(fx, fy, tx, ty); } } putchar();//换行是10,回车13,空格32 } ; }
POJ2155 Matrix二维线段树经典题的更多相关文章
- POJ2155 Matrix 二维线段树
关键词:线段树 二维线段树维护一个 维护一个X线段的线段树,每个X节点维护一个 维护一个Y线段的线段树. 注意,以下代码没有PushDownX.因为如果要这么做,PushDownX时,由于当前X节点的 ...
- hdu1823(二维线段树模板题)
hdu1823 题意 单点更新,求二维区间最值. 分析 二维线段树模板题. 二维线段树实际上就是树套树,即每个结点都要再建一颗线段树,维护对应的信息. 一般一维线段树是切割某一可变区间直到满足所要查询 ...
- POJ 2155 Matrix (二维线段树入门,成段更新,单点查询 / 二维树状数组,区间更新,单点查询)
题意: 有一个n*n的矩阵,初始化全部为0.有2中操作: 1.给一个子矩阵,将这个子矩阵里面所有的0变成1,1变成0:2.询问某点的值 方法一:二维线段树 参考链接: http://blog.csdn ...
- POJ 2155 二维线段树 经典的记录所有修改再统一遍历 单点查询
本来是想找一个二维线段树涉及懒惰标记的,一看这个题,区间修改,单点查询,以为是懒惰标记,敲到一半发现这二维线段树就不适合懒惰标记,你更新了某段的某列,但其实其他段的相应列也要打标记,但因为区间不一样, ...
- poj 2155 matrix 二维线段树 线段树套线段树
题意 一个$n*n$矩阵,初始全为0,每次翻转一个子矩阵,然后单点查找 题解 任意一种能维护二维平面的数据结构都可以 我这里写的是二维线段树,因为四分树的写法复杂度可能会退化,因此考虑用树套树实现二维 ...
- Mosaic HDU 4819 二维线段树入门题
Mosaic Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 102400/102400 K (Java/Others)Total S ...
- poj 2155 matrix 二维线段树
题目链接 区间翻转, 单点查询, 查询操作我真是不太明白...... #include <iostream> #include <vector> #include <cs ...
- POJ2155 Matrix 【二维线段树】
题目链接 POJ2155 题解 二维线段树水题,蒟蒻本想拿来养生一下 数据结构真的是有毒啊,, TM这题卡常 动态开点线段树会TLE[也不知道为什么] 直接开个二维数组反倒能过 #include< ...
- poj 1195:Mobile phones(二维线段树,矩阵求和)
Mobile phones Time Limit: 5000MS Memory Limit: 65536K Total Submissions: 14391 Accepted: 6685 De ...
随机推荐
- 地图编辑器V3
V3.2.4 (2014-07-03) ---------------------------1. 保存地图的锁定与可视状态:2. 地图单独存为map格式结尾的文件与导出的XML文件区别:3. 修正瓷 ...
- CentOS最大文件描述符限制更改
系统级的限制:/proc/sys/fs/file-max中设定了系统最大能打开的文件数. 查看该值可以用如下方式: [root@#panda ~]# cat /proc/sys/fs/file-max ...
- [转]MySQL: Starting MySQL….. ERROR! The server quit without updating PID file
转自: http://icesquare.com/wordpress/mysql-starting-mysql-error-the-server-quit-without-updating-pid-f ...
- BeanShell Assertion in Jmeter
以下为几个beanshell assertion的栗子: if (ResponseCode != null && ResponseCode.equals ("200" ...
- Quartz集群
为什么选择Quartz: 1)资历够老,创立于1998年,比struts1还早,但是一直在更新(27 April 2012: Quartz 2.1.5 Released),文档齐全. 2)完全由Jav ...
- https证书提供商
http://www.itrus.com.cn/verisignchina/About/aboutitrus/Index.html
- jQuery语法
目录: 一.选择网页元素二.改变结果集三.链式操作四.元素的操作五.元素的操作:移动六.元素的操作:复制.删除和创建七.工具方法八.事件操作九.特殊效果 一.选择网页元素这也是jQuery的基本设计思 ...
- 031医疗项目-模块三:药品供应商目录模块——供货商药品目录查询功能----------sql补充知识
这个补充知识有一个点很有必要,视屏上的老师提出一点: 内链接关联查询: 如果表A和表B有一个外键关联 ,可以通过外键进行内链接查询 select dictinfo.*, dicttype.typena ...
- 华为acl(traffic-filter)和dhcp管理
华为alc配置实例:-traffic-filter # 在VLAN100上配置基于ACL的报文过滤,允许源IP地址为192.168.0.2/32的报文通过,丢弃其他报文. <HUAWEI> ...
- 浅谈设计模式--装饰者模式(Decorator Pattern)
挖了设计模式这个坑,得继续填上.继续设计模式之路.这次讨论的模式,是 装饰者模式(Decorator Pattern) 装饰者模式,有时也叫包装者(Wrapper),主要用于静态或动态地为一个特定的对 ...