题意:给你一个矩阵,q次操作,每次查询长宽l的矩阵最大值a和最小值b,然后把中间点换成floor((a+b)/2),

解法:暴力可过,建n颗线段树暴力更新,但是正解应该是树套树,树套树需要注意的是当建树或修改时pushup操作不能直接搞,要先判断是不是外面层的叶子节点,如果是直接修改,如果不是,应该是从外面层的对应子节点更新过来,因为此时的外层树维护的是x轴区间最大和区间最小,需要从x轴两个更小的区间树合并起来更新

//#pragma comment(linker, "/stack:200000000")
//#pragma GCC optimize("Ofast,no-stack-protector")
//#pragma GCC target("sse,sse2,sse3,ssse3,sse4,popcnt,abm,mmx,avx,tune=native")
//#pragma GCC optimize("unroll-loops")
#include<bits/stdc++.h>
#define fi first
#define se second
#define mp make_pair
#define pb push_back
#define pi acos(-1.0)
#define ll long long
#define vi vector<int>
#define mod 1000000007
#define C 0.5772156649
#define ls l,m,rt<<1
#define rs m+1,r,rt<<1|1
#define pil pair<int,ll>
#define pli pair<ll,int>
#define pii pair<int,int>
#define cd complex<double>
#define ull unsigned long long
#define base 1000000000000000000
#define fio ios::sync_with_stdio(false);cin.tie(0) using namespace std; const double g=10.0,eps=1e-;
const int N=+,maxn=+,inf=0x3f3f3f3f,INF=0x3f3f3f3f3f3f3f3f; int c[N][N],n;
struct segtreeinsegtree{
int ma[N<<][N<<],mi[N<<][N<<];
bool leaf;
void pushupx(int id,int rt)
{
ma[id][rt]=max(ma[id<<][rt],ma[id<<|][rt]);
mi[id][rt]=min(mi[id<<][rt],mi[id<<|][rt]);
}
void pushupy(int id,int rt)
{
ma[id][rt]=max(ma[id][rt<<],ma[id][rt<<|]);
mi[id][rt]=min(mi[id][rt<<],mi[id][rt<<|]);
}
void buildy(int id,int x,int l,int r,int rt)
{
if(l==r)
{
if(leaf)ma[id][rt]=mi[id][rt]=c[x][l];
else pushupx(id,rt);//,printf("%d %d %d %d\n",id,x,ma[id][rt]);
return ;
}
int m=(l+r)>>;
buildy(id,x,ls);buildy(id,x,rs);
pushupy(id,rt);
}
void buildx(int xl,int xr,int rt,int yl,int yr)
{
if(xl==xr){leaf=;buildy(rt,xl,yl,yr,);return ;}
int m=(xl+xr)>>;
buildx(xl,m,rt<<,yl,yr);
buildx(m+,xr,rt<<|,yl,yr);
leaf=,buildy(rt,xl,yl,yr,);
}
void updatey(int id,int posx,int posy,int c,int l,int r,int rt)
{
if(l==r)
{
if(leaf)ma[id][rt]=mi[id][rt]=c;
else pushupx(id,rt);
return ;
}
int m=(l+r)>>;
if(posy<=m)updatey(id,posx,posy,c,ls);
else updatey(id,posx,posy,c,rs);
pushupy(id,rt);
}
void updatex(int posx,int posy,int c,int l,int r,int rt)
{
if(l==r){leaf=;updatey(rt,posx,posy,c,,n,);return ;}
int m=(l+r)>>;
if(posx<=m)updatex(posx,posy,c,ls);
else updatex(posx,posy,c,rs);
leaf=,updatey(rt,posx,posy,c,,n,);
}
int querymay(int id,int L,int R,int l,int r,int rt)
{
if(L<=l&&r<=R)return ma[id][rt];
int m=(l+r)>>,ans=;
if(L<=m)ans=max(ans,querymay(id,L,R,ls));
if(m<R)ans=max(ans,querymay(id,L,R,rs));
return ans;
}
int querymax(int xl,int xr,int yl,int yr,int l,int r,int rt)
{
if(xl<=l&&r<=xr){return querymay(rt,yl,yr,,n,);}
int m=(l+r)>>,ans=;
if(xl<=m)ans=max(ans,querymax(xl,xr,yl,yr,ls));
if(m<xr)ans=max(ans,querymax(xl,xr,yl,yr,rs));
return ans;
}
int querymiy(int id,int L,int R,int l,int r,int rt)
{
if(L<=l&&r<=R)return mi[id][rt];
int m=(l+r)>>,ans=1e9+;
if(L<=m)ans=min(ans,querymiy(id,L,R,ls));
if(m<R)ans=min(ans,querymiy(id,L,R,rs));
return ans;
}
int querymix(int xl,int xr,int yl,int yr,int l,int r,int rt)
{
if(xl<=l&&r<=xr)return querymiy(rt,yl,yr,,n,);
int m=(l+r)>>,ans=1e9+;
if(xl<=m)ans=min(ans,querymix(xl,xr,yl,yr,ls));
if(m<xr)ans=min(ans,querymix(xl,xr,yl,yr,rs));
return ans;
}
int query(int x,int y,int l)
{
int xl=max(,x-l/),xr=min(n,x+l/);
int yl=max(,y-l/),yr=min(n,y+l/);
int ma=querymax(xl,xr,yl,yr,,n,);
int mi=querymix(xl,xr,yl,yr,,n,);
// printf("%d %d\n",ma,mi);
int ans=floor(1.0*(ma+mi)/);
updatex(x,y,ans,,n,);
return ans;
}
void debug(int id,int l,int r,int rt)
{
printf("%d %d %d %d\n",l,r,ma[id][rt],mi[id][rt]);
if(l==r)return ;
int m=(l+r)>>;
debug(id,ls);debug(id,rs);
}
}s;
int main()
{
int T,cnt=;scanf("%d",&T);
while(T--)
{
scanf("%d",&n);
for(int i=;i<=n;i++)
for(int j=;j<=n;j++)
scanf("%d",&c[i][j]);
s.buildx(,n,,,n);
// s.debug(5,1,n,1);
int q;scanf("%d",&q);
printf("Case #%d:\n",++cnt);
while(q--)
{
int x,y,l;
scanf("%d%d%d",&x,&y,&l);
printf("%d\n",s.query(x,y,l));
}
}
return ;
}
/***********************
1
3
1 2 3
4 5 6
7 8 9
5
2 2 1
***********************/

UVALive - 6709树套树的更多相关文章

  1. BZOJ 3110: [Zjoi2013]K大数查询 [树套树]

    3110: [Zjoi2013]K大数查询 Time Limit: 20 Sec  Memory Limit: 512 MBSubmit: 6050  Solved: 2007[Submit][Sta ...

  2. BZOJ4170 极光(CDQ分治 或 树套树)

    传送门 BZOJ上的题目没有题面-- [样例输入] 3 5 2 4 3 Query 2 2 Modify 1 3 Query 2 2 Modify 1 2 Query 1 1 [样例输出] 2 3 3 ...

  3. bzoj3262: 陌上花开(树套树)

    #include <iostream> #include <cstdio> #include <cstring> #include <cmath> #i ...

  4. bzoj3295: [Cqoi2011]动态逆序对(树套树)

    #include <iostream> #include <cstdio> #include <cstring> #include <cmath> #i ...

  5. BZOJ 3110 k大数查询 & 树套树

    题意: 有n个位置,每个位置可以看做一个集合,现在要求你实现一个数据结构支持以下功能: 1:在a-b的集合中插入一个数 2:询问a-b集合中所有元素的第k大. SOL: 调得火大! 李建说数据结构题能 ...

  6. BZOJ 3110 树套树 && 永久化标记

    感觉树套树是个非常高深的数据结构.从来没写过 #include <iostream> #include <cstdio> #include <algorithm> ...

  7. 【BZOJ】1901: Zju2112 Dynamic Rankings(区间第k小+树套树)

    http://www.lydsy.com/JudgeOnline/problem.php?id=1901 这题调了我相当长的时间,1wa1a,我是第一次写树套树,这个是树状数组套splay,在每个区间 ...

  8. hdu 4417 Super Mario/树套树

    原题链接:http://acm.hdu.edu.cn/showproblem.php?pid=4417 题意很简单,给定一个序列求一个区间 [L, R,]中小于等于H的元素的个数. 好像函数式线段树可 ...

  9. Uva 3767 Dynamic len(set(a[L:R])) 树套树

    Dynamic len(set(a[L:R])) Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 https://uva.onlinejudge.org/in ...

随机推荐

  1. UVA10100:Longest Match(最长公共子序列)&&HDU1458Common Subsequence ( LCS)

    题目链接:http://blog.csdn.net/u014361775/article/details/42873875 题目解析: 给定两行字符串序列,输出它们之间最大公共子单词的个数 对于给的两 ...

  2. Linux kernel AESNI缓冲区溢出漏洞

    解决办法: CENT OS:升级系统内核. yum update kernel UBUNTU:升级系统内核. #到 Ubuntu网站http://kernel.ubuntu.com/~kernel-p ...

  3. mysql 提示符显示用户,数据库等信息

    命令: mysql -uroot -p --prompt="\\u@\\h:\\d \\r:\\m:\\s>" 效果: root@localhost:(mysql) 02:2 ...

  4. 一步一步学EF系列【5、升级篇 实体与数据库的映射】live writer真坑,第4次补发

    前言 之前的几篇文章,被推荐到首页后,又被博客园下了,原因内容太少,那我要写多点呢,还是就按照这种频率进行写呢?本身我的意图这个系列就是想已最简单最容易理解的方式进行,每篇内容也不要太多,这样初学者容 ...

  5. MySql—模糊查询

    实例: SQL模糊查询,使用like比较关键字,加上SQL里的通配符,请参考以下:  1.LIKE 'Mc%' 将搜索以字母 Mc 开头的所有字符串(如 McBadden).  2.LIKE '%in ...

  6. XDU 1111

    对于一排n个正方形,有f(n)种方案达成目标,若第n个块是白色,则有f(n-1)种方案,若第n个块是黑色,则第n-1个块必为白色,那么有f(n-2)+n-2种方案. 则f(n)=f(n-1)+f(n- ...

  7. yii2使用 db log

    在本地测试的时候,输出log,还是输出到db中比较顺手. 配置过程: 1.加入log组件的配置: 'log' =>[ # 追踪级别 # 消息跟踪级别 # 在开发的时候,通常希望看到每个日志消息来 ...

  8. hdu1403 Longest Common Substring

    地址:http://acm.split.hdu.edu.cn/showproblem.php?pid=1403 题目: Longest Common Substring Time Limit: 800 ...

  9. 337APuzzles

    dangerous /*大水题目.不解释 给你m个数,从中选出n个,保证最大值和最小值的差值最小, 做法:从小到大排序,然后暴力枚举每个长度是n的序列*/ #include<stdio.h> ...

  10. 【VS Error】VS2008在编译时出现:Error 15 Cannot register assembly

    现象: 在visual studio 2008在编译类库时提示如下错误: Error 15 Cannot register assembly "D:\01_Work\02_SVN\OCRpl ...