poj 2155 matrix 二维线段树 线段树套线段树
题意
一个$n*n$矩阵,初始全为0,每次翻转一个子矩阵,然后单点查找
题解
任意一种能维护二维平面的数据结构都可以
我这里写的是二维线段树,
因为四分树的写法复杂度可能会退化,因此考虑用树套树实现二维线段树
简单来说就是每个点都维护了一颗线段树...
因为二维线段树难以实现pushdown,而他的查找又是单点的
于是具体思路类似标记永久化,记录经过的点上的修改次数,最后判断修改次数的奇偶性即可
//为什么不写构造函数和vector?
//因为这是神奇的poj...
- #include<iostream>
- #include<string>
- #include<vector>
- #include<string.h>
- #define endl '\n'
- #define ll long long
- #define ull unsigned long long
- #define fi first
- #define se second
- #define mp make_pair
- #define pii pair<int,int>
- #define all(x) x.begin(),x.end()
- #define IO ios::sync_with_stdio(false)
- #define rep(ii,a,b) for(int ii=a;ii<=b;++ii)
- #define per(ii,a,b) for(int ii=b;ii>=a;--ii)
- #define forn(ii,x) for(int ii=head[x];ii;ii=e[ii].next)
- using namespace std;
- const int maxn=4e3+10,maxm=2e6+10;
- const ll INF=0x3f3f3f3f3f3f3f3f;
- const int mod=1e9+7;
- int casn,n,m,k,d;
- class sstree{
- #define nd node[nowx][nowy]
- public:
- struct segnode {int val;};
- // vector<vector<segnode> > node;
- int n,m,x1,x2,y1,y2,x,nowx;
- int ans;
- segnode node[maxn][maxn];
- void init(int nn,int mm) {
- n=nn,m=mm;
- memset(node ,0,sizeof node);
- // node.resize(n*4+10);
- // rep(i,0,(n*4+9)) node[i].resize(m*4+10);
- }
- void update(int xx1,int xx2,int yy1,int yy2){
- x1=xx1,y1=yy1,x2=xx2,y2=yy2;
- updatex(1,n);
- }
- void updatey(int l,int r,int nowy=1){
- if(y1>r||y2<l) return ;
- if(y1<=l&&y2>=r){nd.val^=1;return ;}
- updatey(l,(l+r)>>1,nowy<<1); updatey(((l+r)>>1)+1,r,nowy<<1|1);
- }
- void updatex(int l,int r,int now=1){
- if(x1>r||x2<l) return ;
- if(x1<=l&&x2>=r) {nowx=now;updatey(1,m);return ;}
- updatex(l,(l+r)>>1,now<<1); updatex(((l+r)>>1)+1,r,now<<1|1);
- }
- int query(int xx,int yy){
- x1=xx,y1=yy;ans=0;
- queryx(1,n);
- return ans;
- }
- void queryy(int l,int r,int nowy=1){
- if(y1>r||y1<l) return ;
- ans^=nd.val;
- if(l==r) return ;
- queryy(l,(l+r)>>1,nowy<<1);queryy(((l+r)>>1)+1,r,nowy<<1|1);
- }
- void queryx(int l,int r,int now=1){
- if(x1>r||x1<l) return ;
- nowx=now;queryy(1,m);
- if(l==r) return ;
- queryx(l,(l+r)>>1,now<<1);queryx(((l+r)>>1)+1,r,now<<1|1);
- }
- }tree;
- int main() {
- IO;
- cin>>casn;
- register int a,b,c,d;
- string s;
- while(casn--){
- cin>>n>>m;
- tree.init(n,n);
- while(m--){
- cin>>s;
- if(s[0]=='C') {
- cin>>a>>b>>c>>d;
- tree.update(a,c,b,d);
- }else {
- cin>>a>>b;
- cout<<tree.query(a,b)<<endl;
- }
- }
- if(casn) cout<<endl;
- }
- }
poj 2155 matrix 二维线段树 线段树套线段树的更多相关文章
- POJ 2155 Matrix (二维线段树入门,成段更新,单点查询 / 二维树状数组,区间更新,单点查询)
题意: 有一个n*n的矩阵,初始化全部为0.有2中操作: 1.给一个子矩阵,将这个子矩阵里面所有的0变成1,1变成0:2.询问某点的值 方法一:二维线段树 参考链接: http://blog.csdn ...
- 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 2155 matrix 二维线段树
题目链接 区间翻转, 单点查询, 查询操作我真是不太明白...... #include <iostream> #include <vector> #include <cs ...
- BZOJ.4553.[HEOI2016&TJOI2016]序列(DP 树状数组套线段树/二维线段树(MLE) 动态开点)
题目链接:BZOJ 洛谷 \(O(n^2)\)DP很好写,对于当前的i从之前满足条件的j中选一个最大值,\(dp[i]=d[j]+1\) for(int j=1; j<i; ++j) if(a[ ...
- bzoj3196 二逼平衡树 树状数组套线段树
题目传送门 思路:树状数组套线段树模板题. 什么是树状数组套线段树,普通的树状数组每个点都是一个权值,而这里的树状数组每个点都是一颗权值线段树,我们用前缀差分的方法求得每个区间的各种信息, 其实关键就 ...
- [bzoj3196][Tyvj1730]二逼平衡树_树套树_位置线段树套非旋转Treap/树状数组套主席树/权值线段树套位置线段树
二逼平衡树 bzoj-3196 Tyvj-1730 题目大意:请写出一个维护序列的数据结构支持:查询给定权值排名:查询区间k小值:单点修改:查询区间内定值前驱:查询区间内定值后继. 注释:$1\le ...
- POJ poj 2155 Matrix
题目链接[http://poj.org/problem?id=2155] /* poj 2155 Matrix 题意:矩阵加减,单点求和 二维线段树,矩阵加减,单点求和. */ using names ...
随机推荐
- 四:OVS+GRE之网络节点
关于Neutron上的三种Agent的作用: Neutron-OVS-Agent:从OVS-Plugin上接收tunnel和tunnel flow的配置,驱动OVS来建立GRE Tunnel Neut ...
- vue webpack打包
webpack构建流程 从启动webpack构建到输出结果经历了一系列过程,它们是: 解析webpack配置参数,合并从shell传入和webpack.config.js文件里配置的参数,生产最后的配 ...
- H5网页后在返回到微信公众平台自定义菜单
<p class="success">订阅成功!</p> <div class="btn" @click="finish ...
- es6可变参数-扩展运算符
es5中参数不确定个数的情况下: //求参数和 function f(){ var a = Array.prototype.slice.call(arguments); var sum = 0; a. ...
- 控制结构(2): 卫语句(guard clause)
// 上一篇:分枝/叶子(branch/leaf) // 下一篇:状态机(state machine) 基于语言提供的基本控制结构,更好地组织和表达程序,需要良好的控制结构. 典型代码: 同步版本 f ...
- Cnario 3.8支持哪些操作系统?
Cnario是基于Windows平台开发的软件,包含Server.Messenger和Player三个组件,支持以下Windows 版本系统: Server/Messenger 支持英文版的以下操作系 ...
- iView组件添加API中介绍的事件的方式(render方式添加事件)
iView组件好用,文档齐全,品质可靠稳定.最大的好处是使用了Vue框架,使很多数据绑定和交互问题变的轻松,是难得的开源前端组件.给作者点个赞.用这个组件来学习Vue.js也是不错的选择. 最近用的比 ...
- 设置 sql_mode
MySQL 的 sql_mode 合理设置 sql_mode 是个很容易被忽视的变量,默认值是空值,在这种设置下是可以允许一些非法操作的,比如允许一些非法数据的插入.在生产环境必须将这个值设置为严格模 ...
- 洛谷 P3327 【[SDOI2015]约数个数和】
前置芝士 关于这个题,你必须知道一个这样奇奇怪怪的式子啊QAQ \[d(i*j)= \sum_{x|i} \sum_{y|j}[gcd(x,y)=1] \] 留坑,先感性理解:后面那个gcd是为了去重 ...
- 自古枪兵幸运E
好梗 求方程的解.n个可以奇数可以偶数,m个必须是偶数 两种方法: 都是O(nlogn)logn是LUCAS定理 法一: 有奇数有偶数,如果都是偶数,那么可以直接除以二然后组合数学 所以枚举有几个奇数 ...