hdu-4819-线段树套线段树
http://acm.hdu.edu.cn/showproblem.php?pid=4819
给出一个N*N的矩阵,每次询问一个m*m的子矩阵里的floor((maxv+minv)/2)并把中间的元素修改为这个值。
线段树套线段树,第一层X表示对行建立的线段树,内层表示对Y也就是列建立的线段树。
分别对X和Y建立相应的函数来完成操作,当更新X树的节点时,再更新完当前X的节点的左右儿子之后,回头对X的这个节点对应的Y树进行更新,相当于X的左右儿子里的Y树来更新X的Y树,能理解这一点就很简单了。
#include<bits/stdc++.h>
using namespace std;
#define pii pair<int,int>
#define mp make_pair
#define LL long long
#define lc (id<<1)
#define rc (id<<1|1)
#define flc (fid<<1)
#define frc (fid<<1|1)
#define mid ((L+R)>>1)
const int maxn=;
int maxv[maxn<<][maxn<<];
int minv[maxn<<][maxn<<];
int a[maxn][maxn],N,x1,x2,y1,y2;
void buildY(int,int,int,int,int,int);
void buildX(int id,int L,int R){
if(L==R){
buildY(id,L,R,,,N);
}
else{
buildX(lc,L,mid);
buildX(rc,mid+,R);
buildY(id,L,R,,,N);
}
}
void buildY(int fid,int fl,int fr,int id,int L,int R){
if(L==R){
if(fl==fr)maxv[fid][id]=minv[fid][id]=a[fl][L];
else{
maxv[fid][id]=max(maxv[flc][id],maxv[frc][id]);
minv[fid][id]=min(minv[flc][id],minv[frc][id]);
}
}
else{
buildY(fid,fl,fr,lc,L,mid);
buildY(fid,fl,fr,rc,mid+,R);
maxv[fid][id]=max(maxv[fid][lc],maxv[fid][rc]);
minv[fid][id]=min(minv[fid][lc],minv[fid][rc]);
}
}
pii askY(int fid,int id,int L,int R){
if(L>=y1&&R<=y2){
return mp(maxv[fid][id],minv[fid][id]);
}
else{
if(y2<=mid) return askY(fid,lc,L,mid);
else if(y1>mid) return askY(fid,rc,mid+,R);
else{
pii pl=askY(fid,lc,L,mid),
pr=askY(fid,rc,mid+,R);
return mp(max(pl.first,pr.first),min(pl.second,pr.second));
}
}
}
pii askX(int id,int L,int R){
if(L>=x1&&R<=x2){
return askY(id,,,N);
}
else{
if(x2<=mid) return askX(lc,L,mid);
else if(x1>mid) return askX(rc,mid+,R);
else{
pii pl=askX(lc,L,mid),
pr=askX(rc,mid+,R);
return mp(max(pl.first,pr.first),min(pl.second,pr.second));
}
}
}
void updateY(int fid,int fl,int fr,int id,int L,int R,int x,int y,int v){
if(L==R){
if(fl==fr){
maxv[fid][id]=minv[fid][id]=v;
}
else{
maxv[fid][id]=max(maxv[flc][id],maxv[frc][id]);
minv[fid][id]=min(minv[flc][id],minv[frc][id]);
}
}
else{
if(y<=mid){
updateY(fid,fl,fr,lc,L,mid,x,y,v);
}
else{
updateY(fid,fl,fr,rc,mid+,R,x,y,v);
}
maxv[fid][id]=max(maxv[fid][lc],maxv[fid][rc]);
minv[fid][id]=min(minv[fid][lc],minv[fid][rc]);
}
}
void updateX(int id,int L,int R,int x,int y,int v){
if(L==R){
updateY(id,L,R,,,N,x,y,v);
}
else{
if(x<=mid) updateX(lc,L,mid,x,y,v);
else updateX(rc,mid+,R,x,y,v);
updateY(id,L,R,,,N,x,y,v);
}
}
int main()
{
int T,M,i,j,x,y,d;
scanf("%d",&T);
for(int cas=;cas<=T;++cas){
scanf("%d",&N);
for(i=;i<=N;++i){
for(j=;j<=N;++j){
scanf("%d",&a[i][j]);
}
}
buildX(,,N);
scanf("%d",&M);
printf("Case #%d:\n",cas);
while(M--){
scanf("%d%d%d",&x,&y,&d);
x1=x-d/,x2=x+d/,y1=y-d/,y2=y+d/;
x1=max(x1,),x2=min(x2,N);
y1=max(y1,),y2=min(y2,N);
pii ans=askX(,,N);
updateX(,,N,x,y,(ans.first+ans.second)/);
printf("%d\n",(ans.first+ans.second)/);
}
}
return ;
}
hdu-4819-线段树套线段树的更多相关文章
- bzoj 3196 Tyvj 1730 二逼平衡树(线段树套名次树)
3196: Tyvj 1730 二逼平衡树 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 1807 Solved: 772[Submit][Stat ...
- [BZOJ 1901] Dynamic Rankings 【树状数组套线段树 || 线段树套线段树】
题目链接:BZOJ - 1901 题目分析 树状数组套线段树或线段树套线段树都可以解决这道题. 第一层是区间,第二层是权值. 空间复杂度和时间复杂度均为 O(n log^2 n). 线段树比树状数组麻 ...
- ZJOI 2017 树状数组(线段树套线段树)
题意 http://uoj.ac/problem/291 思路 不难发现,九条カレン醬所写的树状数组,在查询区间 \([1,r]\) 的时候,其实在查询后缀 \([r,n]\) :在查询 \([l,r ...
- BZOJ4317Atm的树&BZOJ2051A Problem For Fun&BZOJ2117[2010国家集训队]Crash的旅游计划——二分答案+动态点分治(点分树套线段树/点分树+vector)
题目描述 Atm有一段时间在虐qtree的题目,于是,他满脑子都是tree,tree,tree…… 于是,一天晚上他梦到自己被关在了一个有根树中,每条路径都有边权,一个神秘的声音告诉他,每个点到其他的 ...
- dfs序+主席树 或者 树链剖分+主席树(没写) 或者 线段树套线段树 或者 线段树套splay 或者 线段树套树状数组 bzoj 4448
4448: [Scoi2015]情报传递 Time Limit: 20 Sec Memory Limit: 256 MBSubmit: 588 Solved: 308[Submit][Status ...
- 【vijos】1750 建房子(线段树套线段树+前缀和)
https://vijos.org/p/1750 是不是我想复杂了.... 自己yy了个二维线段树,然后愉快的敲打. 但是wa了两法.......sad 原因是在处理第二维的更新出现了个小问题,sad ...
- [TJOI2017][bzoj4889] 不勤劳的图书管理员 [线段树套线段树]
题面 传送门 思路 考虑两本书的位置交换对答案的贡献: (为了方便描述,用"左边那本"和"右边那本"称呼两本我们要交换的书,"中间那本"是我 ...
- 【bzoj4785】[Zjoi2017]树状数组 线段树套线段树
题目描述 漆黑的晚上,九条可怜躺在床上辗转反侧.难以入眠的她想起了若干年前她的一次悲惨的OI 比赛经历.那是一道基础的树状数组题.给出一个长度为 n 的数组 A,初始值都为 0,接下来进行 m 次操作 ...
- BZOJ1901 ZOJ2112 线段树+treap (线段树套线段树)
BZOJ1901: 线段树套线段树做法: (外层线段树 里层动态开节点的权值线段树) 有一个小小的trick 可以省掉二分变成nlog^2n的 就是把查询的区间都取出来- logn个一起走- 2016 ...
随机推荐
- 51nod 1615 跳跃的杰克
http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1615 题意: 思路:一开始是觉得一旦超过了终点,中间某个地方往相反地方跳 ...
- latex建立参考文献的超链接
在Latex生成的pdf文档中建立超链接(如从正文到参考文献,从目录到相应内容,从页码编号到实际页面等),有利于读者快速定位当前阅读的信息. 如何在生成的pdf文件中包含超链接呢?需要注意一下两点: ...
- 【Java】【控制流程】
#栗子 丢手帕 & 菱形 & 金字塔import java.io.*;import java.util.*; public class Test_one { public static ...
- WAI-ARIA无障碍网页应用属性完全展示
本文为原创辛苦之作,尊重劳动,转载请注明来自张鑫旭-鑫空间-鑫生活[http://www.zhangxinxu.com]本文地址:http://www.zhangxinxu.com/wordpress ...
- libxml2_ZC积累
1.Qt5.3.2(VS2010 OpenGL) 1.1.查找节点的 带NameSpace的属性 参考网址:https://stackoverflow.com/questions/7872413/ho ...
- Uncaught TypeError: (intermediate value)(...) is not a function 上一个方法结束没有加分号; 代码解析报错
Uncaught TypeError: (intermediate value)(...) is not a function 别忽略了, 第一个方法后面的结束 分号; 不起眼的,引来麻烦, 哎,规 ...
- android状态栏和NavigationBar的动态控制显示
项目在开发阅读器,阅读器对阅读界面的要求就是在工具栏不显示的状态下,ActionBar和NavigationBar都是不显示的,当工具栏显示时它们都出来,这就需要动态控制它们的显示与隐藏. 第一阶段: ...
- hybrid cordova+vue开发APP(一) 环境搭建
没有选择react-navite,而选择cordova+vue2.x,是因为react-navite有学习成本,并且cordova+vue2.x程序员 可以直接上手,性能上可以满足需求,成本低,开发速 ...
- gulp自动化打包工具
/** * Created by hasee on 2016/7/5. */var gulp = require('gulp');var sass = require('gulp-sass');//容 ...
- 第 8 章 容器网络 - 051 - 在 overlay 中运行容器
在 overlay 中运行容器 运行一个 busybox 容器并连接到 ov_net1: docker run -itd --name bbox1 --network ov_net1 busybox ...