【HDU 4819】Mosaic
【题目链接】
【算法】
二维线段树(树套树)
【代码】
#include<bits/stdc++.h>
using namespace std;
#define MAXN 800 int i,q,n,xa,xb,ya,yb,l,tmp,T,Max,Min,x,y; struct info { int Max,Min; } Tree[MAXN*][MAXN*]; template <typename T> inline void read(T &x) {
int f = ; x = ;
char c = getchar();
for (; !isdigit(c); c = getchar()) { if (c == '-') f = -f; }
for (; isdigit(c); c = getchar()) x = (x << ) + (x << ) + c - '';
x *= f;
}
template <typename T> inline void write(T x) {
if (x < ) { putchar('-'); x = -x; }
if (x > ) write(x/);
putchar(x%+'');
}
template <typename T> inline void writeln(T x) {
write(x);
puts("");
} inline void push_up(int D,int index) {
Tree[D][index].Max = max(Tree[D][index<<].Max,Tree[D][index<<|].Max);
Tree[D][index].Min = min(Tree[D][index<<].Min,Tree[D][index<<|].Min);
} inline void build_y(int D,int index,int l,int r,int opt) {
int mid,val;
if (l == r) {
if (opt == ) {
read(val);
Tree[D][index].Max = Tree[D][index].Min = val;
} else {
Tree[D][index].Max = max(Tree[D<<][index].Max,Tree[D<<|][index].Max);
Tree[D][index].Min = min(Tree[D<<][index].Min,Tree[D<<|][index].Min);
}
return;
}
mid = (l + r) >> ;
build_y(D,index<<,l,mid,opt);
build_y(D,index<<|,mid+,r,opt);
push_up(D,index);
} inline void build_x(int index,int l,int r) {
int mid;
if (l == r) {
build_y(index,,,n,);
return;
}
mid = (l + r) >> ;
build_x(index<<,l,mid);
build_x(index<<|,mid+,r);
build_y(index,,,n,);
} inline void modify_y(int D,int index,int l,int r,int val,int opt) {
int mid;
if (l == r) {
if (opt == ) Tree[D][index].Max = Tree[D][index].Min = val;
else {
Tree[D][index].Max = max(Tree[D<<][index].Max,Tree[D<<|][index].Max);
Tree[D][index].Min = min(Tree[D<<][index].Min,Tree[D<<|][index].Min);
}
return;
}
mid = (l + r) >> ;
if (mid >= y) modify_y(D,index<<,l,mid,val,opt);
else modify_y(D,index<<|,mid+,r,val,opt);
push_up(D,index);
} inline void modify_x(int index,int l,int r,int val) {
int mid;
if (l == r) {
modify_y(index,,,n,val,);
return;
}
mid = (l + r) >> ;
if (mid >= x) modify_x(index<<,l,mid,val);
else modify_x(index<<|,mid+,r,val);
modify_y(index,,,n,val,);
} inline int query_min_y(int D,int index,int l,int r,int x,int y) {
int mid;
if (l == x && r == y) return Tree[D][index].Min;
mid = (l + r) >> ;
if (mid >= y) return query_min_y(D,index<<,l,mid,x,y);
else if (mid + <= x) return query_min_y(D,index<<|,mid+,r,x,y);
else return min(query_min_y(D,index<<,l,mid,x,mid),query_min_y(D,index<<|,mid+,r,mid+,y));
} inline int query_min_x(int index,int l,int r,int x,int y) {
int mid;
if (l == x && r == y) return query_min_y(index,,,n,ya,yb);
mid = (l + r) >> ;
if (mid >= y) return query_min_x(index<<,l,mid,x,y);
else if (mid + <= x) return query_min_x(index<<|,mid+,r,x,y);
else return min(query_min_x(index<<,l,mid,x,mid),query_min_x(index<<|,mid+,r,mid+,y));
} inline int query_max_y(int D,int index,int l,int r,int x,int y) {
int mid;
if (l == x && r == y) return Tree[D][index].Max;
mid = (l + r) >> ;
if (mid >= y) return query_max_y(D,index<<,l,mid,x,y);
else if (mid + <= x) return query_max_y(D,index<<|,mid+,r,x,y);
else return max(query_max_y(D,index<<,l,mid,x,mid),query_max_y(D,index<<|,mid+,r,mid+,y));
} inline int query_max_x(int index,int l,int r,int x,int y) {
int mid;
if (l == x && r == y) return query_max_y(index,,,n,ya,yb);
mid = (l + r) >> ;
if (mid >= y) return query_max_x(index<<,l,mid,x,y);
else if (mid + <= x) return query_max_x(index<<|,mid+,r,x,y);
else return max(query_max_x(index<<,l,mid,x,mid),query_max_x(index<<|,mid+,r,mid+,y));
} int main() { read(T);
for (i = ; i <= T; i++) {
read(n);
build_x(,,n);
read(q);
cout<<"Case #"<< i << ':' << endl;
while (q--) {
read(x); read(y); read(l);
xa = max(,x-l/);
xb = min(n,x+l/);
ya = max(,y-l/);
yb = min(n,y+l/);
Max = query_max_x(,,n,xa,xb);
Min = query_min_x(,,n,xa,xb);
tmp = (Max + Min) / ;
writeln(tmp);
modify_x(,,n,tmp);
}
}
return ;
}
【HDU 4819】Mosaic的更多相关文章
- 【数位dp】【HDU 3555】【HDU 2089】数位DP入门题
[HDU 3555]原题直通车: 代码: // 31MS 900K 909 B G++ #include<iostream> #include<cstdio> #includ ...
- 【HDU 5647】DZY Loves Connecting(树DP)
pid=5647">[HDU 5647]DZY Loves Connecting(树DP) DZY Loves Connecting Time Limit: 4000/2000 MS ...
- -【线性基】【BZOJ 2460】【BZOJ 2115】【HDU 3949】
[把三道我做过的线性基题目放在一起总结一下,代码都挺简单,主要就是贪心思想和异或的高斯消元] [然后把网上的讲解归纳一下] 1.线性基: 若干数的线性基是一组数a1,a2,a3...an,其中ax的最 ...
- 【HDU 2196】 Computer(树的直径)
[HDU 2196] Computer(树的直径) 题链http://acm.hdu.edu.cn/showproblem.php?pid=2196 这题可以用树形DP解决,自然也可以用最直观的方法解 ...
- 【HDU 2196】 Computer (树形DP)
[HDU 2196] Computer 题链http://acm.hdu.edu.cn/showproblem.php?pid=2196 刘汝佳<算法竞赛入门经典>P282页留下了这个问题 ...
- 【HDU 5145】 NPY and girls(组合+莫队)
pid=5145">[HDU 5145] NPY and girls(组合+莫队) NPY and girls Time Limit: 8000/4000 MS (Java/Other ...
- 【hdu 1043】Eight
[题目链接]:http://acm.hdu.edu.cn/showproblem.php?pid=1043 [题意] 会给你很多组数据; 让你输出这组数据到目标状态的具体步骤; [题解] 从12345 ...
- 【HDU 3068】 最长回文
[题目链接] http://acm.hdu.edu.cn/showproblem.php?pid=3068 [算法] Manacher算法求最长回文子串 [代码] #include<bits/s ...
- 【HDU 4699】 Editor
[题目链接] http://acm.hdu.edu.cn/showproblem.php?pid=4699 [算法] 维护两个栈,一个栈放光标之前的数,另外一个放光标之后的数 在维护栈的同时求最大前缀 ...
随机推荐
- HDU 5905 Black White Tree(树型DP)
题目链接 Black White Tree 树型DP,设$f[i][j]$为以$i$为根的子树中大小为$j$的连通块中可以包含的最小黑点数目. $g[i][j]$为以$i$为根的子树中大小为$j$的 ...
- Python3:urllib模块的使用
Python3:urllib模块的使用1.基本方法 urllib.request.urlopen(url, data=None, [timeout, ]*, cafile=None, capath=N ...
- Access restriction: The method 'CharacterEncoder.encode(byte[])' is not API...
问题描述:Access restriction: The method 'CharacterEncoder.encode(byte[])' is not API... 解决方法:这种错误是eclips ...
- 让win7任务条上的文件夹打开是c,d,e,f而不是库
如果资源管理器是打开的,则右键点击资源管理器的图标,在跳出的菜单中,右键点击“Windows资源管理器”,选择“属性”. 在“快捷方式’选项卡,“目标”一栏,默认的是 %windir%\explore ...
- 使用java连接AD域,验证账号密码是否正确
eb项目中有时候客户要求我们使用ad域进行身份确认,不再另外做一套用户管理系统.其实客户就是只要一套账号可以访问所有的OA,CRM等办公系统.这就是第三方验证.一般有AD域,Ldap,Radius,邮 ...
- Map与object的区别
Map 对象保存键值对.任何值(对象或者原始值) 都可以作为一个键或一个值. 语法 new Map([iterable]) 参数 iterable Iterable 可以是一个数组或者其他 itera ...
- Thinking in React(翻译)
下面是React官方文档中的Thinking inReact文章的翻译,第一次翻译英文的文章,肯定有非常多不对的地方,还望多多包涵. 原文地址:https://facebook.github.io/r ...
- 利用卷积神经网络(CNN)构造社区问答系统
/* 版权声明:能够随意转载,转载时请标明文章原始出处和作者信息 .*/ author: 张俊林 ...
- 1 npoi 网上 不用模板 设置密码 workbook.WriteProtectWorkbook("password", "admin"); 、、 2 locked.IsLocked = true; sheet1.ProtectSheet("password");NPOI操作EXCEL--设置密码才可以修改单元格内容 3 模板设置密码 确定原密码 设置新密码
1 workbook.WriteProtectWorkbook("password", "admin"); 还是可以进去 只读进去 可以编辑 编辑就另存为 ...
- C#3.0之神奇的Lambda表达式和Lambda语句
“Lambda 表达式”是一个匿名函数,它可以包含表达式和语句,并且可用于创建委托或表达式目录树类型.所有 Lambda 表达式都使用 Lambda 运算符 =>,该运算符读为“goes to” ...