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这个格 ...
随机推荐
- express+nodecoffee写passport登录验证实例(一)
项目中要用到passport登录验证,环境如标题样:express框架,coffee模版引擎,node后台 一:建项目 直接用express命令建,虽然默认模版为jade,可以手动换成coffee哦. ...
- CSS3 Media Queries
Media Queries直译过来就是“媒体查询”,在我们平时的Web页面中head部分常看到这样的一段代码: <link href="css/reset.css" rel= ...
- 为什么 Node.js 这么火,而同样异步模式 Python 框架 Twisted 却十几年一直不温不火?
twisted是一个强大的异步网络框架,应用的面也非常广,但是没有这几年才出现的Node.js火,社区.文档也是很少可怜我觉得二者其实在本质上差不多,而且python使用起来还是比较容易一些的 匿名用 ...
- linux常用的重要的命令: netstat
Netstat 命令用于显示各种网络相关信息,如网络连接,路由表,接口状态 (Interface Statistics),masquerade 连接,多播成员 (Multicast Membershi ...
- Ibatis.Net 各种配置说明(二)
一.各个配置文件的作用说明 providers.config:指定数据库提供者,.Net版本等信息. xxxxx.xml:映射规则. SqlMap.config:大部分配置一般都在这里,如数据库连接等 ...
- C++-什么时候需要在类的构造函数中使用初始化列表
1,如果基类没有default构造函数,则意味着其不能自己初始化.如果其被派生,派生类的构造函数要负责调用基类的构造函数,并传递给它需要的参数.下例中Base 2,如果类成员没有默认构造函数.下例中E ...
- Hibernate中的集合映射
1.定义实体 public class User { private int userId; private String userName; private Set<String> ad ...
- Jquery easyui datagrid 导出Excel
From:http://www.cnblogs.com/weiqt/articles/4022399.html datagrid的扩展方法,用于将当前的数据生成excel需要的内容. 1 <sc ...
- [vijos P1023] Victoria的舞会3
这… 本来想学习一下Tarjan算法的,没想到码都码好了发现这题不是求强连通分量而是简单的连通分量…图论基础都还给老师了啊啊啊!最后深搜通通解决! v标记是否被访问过,scc标记每个的祖先(本来想写T ...
- C/C++遍历Windows文件夹下的所有文件
因为文件夹中往往包含文件和文件夹.想要遍历所有的文件,必须遍历文件夹中所有的文件夹.很显然,这个描述满足递归的两个要素:(1)问题的规模在不断的缩小,且新问题的模式与旧问题相同.很显然文件夹中含有子文 ...