HDU 4819 Mosaic(13年长春现场 二维线段树)
HDU 4819 Mosaic
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4819
题意:给定一个n*n的矩阵,每次给定一个子矩阵区域(x,y,l),求出该区域内的最大值(A)和最小值(B),输出(A+B)/2,并用这个值更新矩阵[x,y]的值
思路:裸的二维线段树,用树套树实现
# include<cstdio>
# include<cstring>
# include<algorithm>
using namespace std; # define lson l,m,rt<<
# define rson m+,r,rt<<|
# define MAXN
int xL,xR,yL,yR,val;
int maxv,minv;
int Max[MAXN<<][MAXN<<],Min[MAXN<<][MAXN<<];
int N,mat[MAXN][MAXN]; void PushUp(int xrt,int rt)
{
Max[xrt][rt]=max(Max[xrt][rt<<],Max[xrt][rt<<|]);
Min[xrt][rt]=min(Min[xrt][rt<<],Min[xrt][rt<<|]);
} void BuildY(int xrt,int x,int l,int r,int rt)
{
int m;
if(l==r)
{
if(x!=-) Max[xrt][rt]=Min[xrt][rt]=mat[x][l];
else
{
Max[xrt][rt]=max(Max[xrt<<][rt],Max[xrt<<|][rt]);
Min[xrt][rt]=min(Min[xrt<<][rt],Min[xrt<<|][rt]);
}
return;
}
m=(l+r)>>;
BuildY(xrt,x,lson);
BuildY(xrt,x,rson);
PushUp(xrt,rt);
} void BuildX(int l,int r,int rt)
{
int m;
if(l==r)
{
BuildY(rt,l,,N,);
return;
}
m=(l+r)>>;
BuildX(lson);
BuildX(rson);
BuildY(rt,-,,N,);
} void UpdateY(int xrt,int x,int l,int r,int rt)
{
int m;
if(l==r)
{
if(x!=-) Max[xrt][rt]=Min[xrt][rt]=val;
else
{
Max[xrt][rt]=max(Max[xrt<<][rt],Max[xrt<<|][rt]);
Min[xrt][rt]=min(Min[xrt<<][rt],Min[xrt<<|][rt]);
}
return;
}
m=(l+r)>>;
if(yL<=m) UpdateY(xrt,x,lson);
else UpdateY(xrt,x,rson);
PushUp(xrt,rt);
} void UpdateX(int l,int r,int rt)
{
int m;
if(l==r)
{
UpdateY(rt,l,,N,);
return;
}
m=(l+r)>>;
if(xL<=m) UpdateX(lson);
else UpdateX(rson);
UpdateY(rt,-,,N,);
} void QueryY(int xrt,int l,int r,int rt)
{
int m;
if(yL<=l&&yR>=r)
{
minv=min(minv,Min[xrt][rt]);
maxv=max(maxv,Max[xrt][rt]);
return;
}
m=(l+r)>>;
if(yL<=m) QueryY(xrt,lson);
if(yR>m) QueryY(xrt, rson);
} void QueryX(int l,int r,int rt)
{
int m;
if(xL<=l&&xR>=r)
{
QueryY(rt,,N,);
return;
}
m=(l+r)>>;
if(xL<=m) QueryX(lson);
if(xR>m) QueryX(rson);
} int main()
{
//freopen("in.txt","r",stdin);
int i,j,q,cas,T,x,y,l;
char op[];
scanf("%d",&T);
for(cas=;cas<=T;cas++)
{
scanf("%d",&N);
for(i=;i<=N;i++)
for(j=;j<=N;j++)
scanf("%d",&mat[i][j]);
BuildX(,N,);
scanf("%d",&q);
printf("Case #%d:\n",cas);
while(q--)
{
scanf("%d%d%d",&x,&y,&l);
l=(l+)/;
xL=max(,x-l+),xR=min(N,x+l-);
yL=max(,y-l+),yR=min(N,y+l-);
minv=<<,maxv=-(<<);
QueryX(,N,);
val=(maxv+minv)/;
xL=x,yL=y;
printf("%d\n",val);
UpdateX(,N,);
}
}
return ;
}
HDU 4819
HDU 4819 Mosaic(13年长春现场 二维线段树)的更多相关文章
- HDU 4819 Mosaic (二维线段树)
Mosaic Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 102400/102400 K (Java/Others)Total S ...
- HDU 4819 Mosaic 二维线段树
Mosaic Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://acm.hust.edu.cn/vjudge/contest/view.action ...
- HDU 4819 Mosaic --二维线段树(树套树)
题意: 给一个矩阵,每次查询一个子矩阵内的最大最小值,然后更新子矩阵中心点为(Max+Min)/2. 解法: 由于是矩阵,且要求区间最大最小和更新单点,很容易想到二维的线段树,可是因为之前没写过二维的 ...
- HDU 4819 Mosaic (二维线段树&区间最值)题解
思路: 二维线段树模板题,马克一下,以后当模板用 代码: #include<cstdio> #include<cmath> #include<cstring> #i ...
- HDU 4819 Mosaic 【二维线段树】
题目大意:给你一个n*n的矩阵,每次找到一个点(x,y)周围l*l的子矩阵中的最大值a和最小值b,将(x,y)更新为(a+b)/2 思路:裸的二维线段树 #include<iostream> ...
- hdu 4819 二维线段树模板
/* HDU 4819 Mosaic 题意:查询某个矩形内的最大最小值, 修改矩形内某点的值为该矩形(Mi+MA)/2; 二维线段树模板: 区间最值,单点更新. */ #include<bits ...
- HDU 4819 二维线段树
13年长春现场赛的G题,赤裸裸的二维线段树,单点更新,区间查询 不过我是第一次写二维的,一开始写T了,原因是我没有好好利用行段,说白一点,还是相当于枚举行,然后对列进行线段树,那要你写二维线段树干嘛 ...
- HDU 1823 Luck and Love(二维线段树)
之前只知道这个东西的大概概念,没具体去写,最近呵呵,今补上. 二维线段树 -- 点更段查 #include <cstdio> #include <cstring> #inclu ...
- UVALive 6709 - Mosaic 二维线段树
题目链接 给一个n*n的方格, 每个方格有值. 每次询问, 给出三个数x, y, l, 求出以x, y为中心的边长为l的正方形内的最大值与最小值, 输出(maxx+minn)/2, 并将x, y这个格 ...
随机推荐
- SqlHelper帮助类
数据库连接字符串//Data Source=.;Initial Catalog=Test1;User Id=sa;Password=123456; public static class SqlHel ...
- Scala 入门——Eclipse开发环境搭建
Come From: http://lidrema.blog.163.com/blog/static/209702148201461145859142/ Scala: 一种类似java的编程.集成了面 ...
- 基于TCP的通信 客户端
#include <WINSOCK2.H> #include <stdio.h> // socket 套接字 #pragma comment (lib,"Ws2_32 ...
- Asynchttpclient开源框架下载图片和文本,于Volley和Glide开源框架的区别。
AsyncHttpClient是一款比较流行的Android异步网路加载库,在github上的网址是:https://github.com/loopj/android-async-httpAsyncH ...
- ASP.NET伪静态 UrlRewrite(Url重写) 实现和配置
核心提示:大家一定经常在网络上看到很多网站的地址后缀都是用XX.HTML或者XX.ASPX等类似静态文件的标示来操作的吧,那么大家有怀疑过他真的是一个一个的静态生成的文件么,静态文件的生成的优缺有好有 ...
- html5+js实现刮刮卡效果
通过Canvas实现的可刮涂层效果. 修改img.src时涂层也会自动适应新图片的尺寸. 修改layer函数可更改涂层样式. 涂层: 可刮效果: <!DOCTYPE html> <h ...
- word2vec使用说明
word2vec是一个将单词转换成向量形式的工具.可以把对文本内容的处理简化为向量空间中的向量运算,计算出向量空间上的相似度,来表示文本语义上的相似度. 一.理论概述 (主要来源于http://lic ...
- Linux 常用命令杂记
移动光标:h:向左移动j:向下移动k:向上移动l:向上移动 与window 光标移动键功能一致. 常用命令行:shift + ^ 行首shift + $ 行尾ctrl + v 可视模式 , 选择一个范 ...
- AJAX初步
1.什么是AJAX 客户端与服务器,可以在[不必刷新整个浏览器]的情况下,与服务器进行异步通讯的技术,即,AJAX是一个[局部刷新]的[异步]通讯技术: AJAX不是全新的语言,是2005年Googl ...
- outlook新邮件到达提醒设置以及outlook最小化到托盘设置
有些邮件是需要马上处理的,因此希望能在收到邮件之后马上就知道,但是有不希望频繁的去检查有没有.outlook可以帮我们轻松做到新邮件到达提醒. 一 .设置outlook新邮件到达提醒:选项->电 ...