HDU 4819 Mosaic D区段树
连接: pid=4819">http://acm.hdu.edu.cn/showproblem.php?pid=4819
意:给出一个800×800下面的矩阵。每次更新一个点的值为以这个点为中心的长度为Li的矩阵内的最大值和最小值的平均值。而且输出这个值。
思路:线段树模板题。二维线段树就是一个树套树的情况。
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvb29vb29vb29l/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="">
题的意义就在于给我带了一个二维线段树的模板,跑了2359ms。结构体的线段树不会被卡。
代码:
#include <iostream>
#include <cstdio>
#include <cstring>
#include <cmath>
#include <map>
#include <cstdlib>
#include <queue>
#include <stack>
#include <vector>
#include <ctype.h>
#include <algorithm>
#include <string>
#include <set>
#define PI acos(-1.0)
#define maxn 1000
#define INF 0x7fffffff
#define eps 1e-16
#define MOD 1000000009
typedef long long LL;
typedef unsigned long long ULL;
using namespace std;
int x_pos[maxn],y_pos[maxn];
int n;//y最大范围
struct y_line
{
int left,right;
int Max,Min;
//int sum;
int mid(){return (left+right)>>1;}
};
struct x_line
{
int left,right;
y_line yy[maxn*4];
int mid(){return (left+right)>>1;}
void build_ytree(int i,int l,int r)
{
yy[i].Max=-INF;
yy[i].Min=INF;
yy[i].left=l;
yy[i].right=r;
if(l==r)
{
y_pos[l]=i;
return ;
}
build_ytree(i<<1,l,yy[i].mid());
build_ytree(i<<1|1,yy[i].mid()+1,r);
}
int query_Min(int i,int y1,int y2)
{
if(yy[i].left==y1&&yy[i].right==y2)
return yy[i].Min;
if(yy[i].mid()>=y2)
return query_Min(i<<1,y1,y2);
if(yy[i].mid()<y1)
return query_Min(i<<1|1,y1,y2);
return min(query_Min(i<<1,y1,yy[i].mid()),query_Min(i<<1|1,yy[i].mid()+1,y2));
}
int query_Max(int i,int y1,int y2)
{
if(yy[i].left==y1&&yy[i].right==y2)
return yy[i].Max;
if(yy[i].mid()>=y2)
return query_Max(i<<1,y1,y2);
if(yy[i].mid()<y1)
return query_Max(i<<1|1,y1,y2);
return max(query_Max(i<<1,y1,yy[i].mid()),query_Max(i<<1|1,yy[i].mid()+1,y2));
}
}xx[maxn*4];
void build_xtree(int i,int l,int r)
{
xx[i].left=l;
xx[i].right=r;
xx[i].build_ytree(1,1,n);
if(l==r)
{
x_pos[l]=i;
return ;
}
build_xtree(i<<1,l,xx[i].mid());
build_xtree(i<<1|1,xx[i].mid()+1,r);
}
void change(int x,int y,int num)
{
int x_p=x_pos[x],y_p=y_pos[y];
for(int i=x_p;i>0;i>>=1)
for(int j=y_p;j>0;j>>=1)
if(j==y_p&&i==x_p)
{
xx[i].yy[j].Max=xx[i].yy[j].Min=num;
}
else if(j==y_p)
{
xx[i].yy[j].Max=max(xx[i<<1].yy[j].Max,xx[i<<1|1].yy[j].Max);
xx[i].yy[j].Min=min(xx[i<<1].yy[j].Min,xx[i<<1|1].yy[j].Min);
}
else
{
xx[i].yy[j].Max=max(xx[i].yy[j<<1].Max,xx[i].yy[j<<1|1].Max);
xx[i].yy[j].Min=min(xx[i].yy[j<<1].Min,xx[i].yy[j<<1|1].Min);
}
}
int query_Min(int i,int x1,int y1,int x2,int y2)
{
if(xx[i].left==x1&&xx[i].right==x2)
return xx[i].query_Min(1,y1,y2);
if(xx[i].mid()>=x2)
return query_Min(i<<1,x1,y1,x2,y2);
if(xx[i].mid()<x1)
return query_Min(i<<1|1,x1,y1,x2,y2);
return min(query_Min(i<<1,x1,y1,xx[i].mid(),y2),query_Min(i<<1|1,xx[i].mid()+1,y1,x2,y2));
}
int query_Max(int i,int x1,int y1,int x2,int y2)
{
if(xx[i].left==x1&&xx[i].right==x2)
return xx[i].query_Max(1,y1,y2);
if(xx[i].mid()>=x2)
return query_Max(i<<1,x1,y1,x2,y2);
if(xx[i].mid()<x1)
return query_Max(i<<1|1,x1,y1,x2,y2);
return max(query_Max(i<<1,x1,y1,xx[i].mid(),y2),query_Max(i<<1|1,xx[i].mid()+1,y1,x2,y2));
}
int main()
{
int T,tot,c_x,c_y,r;
scanf("%d",&T);
for(int ii=1;ii<=T;ii++)
{
scanf("%d",&n);
build_xtree(1,1,n);
for(int i=1;i<=n;i++)
for(int j=1;j<=n;j++)
{
int x;
scanf("%d",&x);
change(i,j,x);
}
scanf("%d",&tot);
printf("Case #%d:\n",ii);
for(int i=0;i<tot;i++)
{
scanf("%d%d%d",&c_x,&c_y,&r);
int a,b,c,d;
a=max(1,c_x-r/2);
b=max(1,c_y-r/2);
c=min(n,c_x+r/2);
d=min(n,c_y+r/2);
int t_min=query_Min(1,a,b,c,d);
int t_max=query_Max(1,a,b,c,d);
int t_need=(t_min+t_max)>>1;
change(c_x,c_y,t_need);
printf("%d\n",t_need);
}
}
return 0;
}
版权声明:本文博客原创文章,博客,未经同意,不得转载。
HDU 4819 Mosaic D区段树的更多相关文章
- HDU 4819 Mosaic(13年长春现场 二维线段树)
HDU 4819 Mosaic 题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4819 题意:给定一个n*n的矩阵,每次给定一个子矩阵区域(x,y,l) ...
- hdu 4819 二维线段树模板
/* HDU 4819 Mosaic 题意:查询某个矩形内的最大最小值, 修改矩形内某点的值为该矩形(Mi+MA)/2; 二维线段树模板: 区间最值,单点更新. */ #include<bits ...
- 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 树套树 模板
The God of sheep decides to pixelate some pictures (i.e., change them into pictures with mosaic). He ...
- HDU 4819 Mosaic --二维线段树(树套树)
题意: 给一个矩阵,每次查询一个子矩阵内的最大最小值,然后更新子矩阵中心点为(Max+Min)/2. 解法: 由于是矩阵,且要求区间最大最小和更新单点,很容易想到二维的线段树,可是因为之前没写过二维的 ...
- Mosaic HDU 4819 二维线段树入门题
Mosaic Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 102400/102400 K (Java/Others)Total S ...
- 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> ...
随机推荐
- Linux中块设备驱动程序分析
基于<Linux设备驱动程序>书中的sbull程序以对Linux块设备驱动总结分析. 開始之前先来了解这个块设备中的核心数据结构: struct sbull_dev { i ...
- HttpDNS 服务详解(转)
但凡使用域名来给用户提供服务的互联网企业,都或多或少地无法避免在有中国特色的互联网环境中遭遇到各种域名被缓存.用户跨网访问缓慢等问题.那么对于腾讯这样的域名数量在10万级别的互联网公司来讲,域名解析异 ...
- Redis安装及简单測试
摘要: Redis是眼下业界很受到欢迎的一个内存数据库,一般用作系统的中间缓存系统,用以提升总体商业系统的吞吐量和响应速度.本文将简要介绍安装的主要过程以及给出一个简要的測试代码. 1. 系统环境和 ...
- Android 下拉刷新上拉载入效果功能
应用场景: 在App开发中,对于信息的获取与演示.不可能所有将其获取与演示,为了在用户使用中,给予用户以友好.方便的用户体验,以滑动.下拉的效果动态载入数据的要求就会出现. 为此.该效果功能就须要应用 ...
- ByteBuffer的allocate和allocateDirect
在Java中当我们要对数据进行更底层的操作时,一般是操作数据的字节(byte)形式,这时经常会用到ByteBuffer这样一个类.ByteBuffer提供了两种静态实例方式: public stati ...
- Git使用操作指南和GitHub
本文记录Git的使用操作,把散落的记忆整理到一起.并介绍GitHub的使用. 使用Git代表着一种思想和境地,和SVN相比,不是技术上的差异有多么大,而是代表融入了一种新的生态环境.一种开放开源的心态 ...
- 趣味Java算法题(附答案)
[程序1] 题目:古典问题:有一对兔子,从出生后第3个月起每一个月都生一对兔子,小兔子长到第三个月后每一个月又生一对兔子,假如兔子都不死,问每一个月的兔子总数为多少? //这是一个菲波拉契 ...
- 产品经理(五岁以下儿童)myVegas Slots排名上升的秘密
myVEGAS Slots于AppStore上排名在今年也就是2月份时候飙升,那么什么情况导致这个现象的呢,我们试图通过App Annie的分析给出答案. 上面是myVegas的排名情况,我们能够看到 ...
- 3Dmax+blend+WPF综合运用
原文:3Dmax+blend+WPF综合运用 赛后总结 本人小菜,WPF刚入门,只是写一下最近的项目心得.欢迎各位前辈们前来拍砖指正,感激不敬!先申明,小弟我入门仓促,很多东西也是一知半解,所以很多问 ...
- 转载:Raspberry Pi 树莓派入门
转载说明: 整理转载,原文链接http://www.eeboard.com/bbs/thread-5191-1-1.html 这篇帖子我打算用Q&A的方式来编写,这样大家更容易一目了然的看明整 ...