HDU1823-Luck and Love-二维线段树(模板)
题目链接:http://acm.hdu.edu.cn/showproblem.php?
pid=1823
好吧,给这题跪了。
。。orz....
一道非常基础的二维线段树的模板题;
可是细节非常多;尤其注意了;
swap函数会丢失精度,用double就等着WA到死吧。
。
。
orz...
还有就是给你的区间不一定是按顺序的。得加一个推断;真的是坑。。。orz....
#include<iostream>
#include<string>
#include<cstdio>
#include<cstring>
#include<queue>
#include<map>
#include<cmath>
#include<stack>
#include<set>
#include<vector>
#include<algorithm>
#define LL long long
#define inf 1<<30
#define s(a) scanf("%d",&a)
#define CL(a,b) memset(a,b,sizeof(a))
using namespace std;
const int N=5005;
int n,a,b;
float seg[N][N<<2]; // 表示X轴Y轴。
void Build_2(int l,int r,int deep,int rt) // 建y轴方向线段树(二维);
{
seg[deep][rt]=-1.0;
if(l==r) return;
int mid=(l+r)>>1;
Build_2(l,mid,deep,rt<<1);
Build_2(mid+1,r,deep,rt<<1|1);
}
void Build(int l,int r,int rt) // 建x轴方向线段树(一维)。
{
Build_2(0,1000,rt,1);
if(l==r) return;
int mid=(l+r)>>1;
Build(l,mid,rt<<1);
Build(mid+1,r,rt<<1|1);
}
void Insert_2(int act,float love,int l,int r,int deep,int rt) // y轴方向更新数据;(二维)
{
seg[deep][rt]=max(love,seg[deep][rt]);
if(l==r) return;
int mid=(l+r)>>1;
if(act<=mid) Insert_2(act,love,l,mid,deep,rt<<1);
else Insert_2(act,love,mid+1,r,deep,rt<<1|1);
seg[deep][rt]=max(seg[deep][rt<<1],seg[deep][rt<<1|1]);
}
void Insert(int h,int act,float love,int l,int r,int rt) // x轴,一维;
{
Insert_2(act,love,0,1000,rt,1);
if(l==r) return;
int mid=(l+r)>>1;
if(h<=mid) Insert(h,act,love,l,mid,rt<<1);
else Insert(h,act,love,mid+1,r,rt<<1|1);
}
float Query_2(int L,int R,int l,int r,int rt,int deep) // 查询,y轴,二维;
{
if(L<=l&&R>=r) return seg[deep][rt];
int mid=(l+r)>>1;
if(R<=mid) return Query_2(L,R,l,mid,rt<<1,deep);
else if(L>mid) return Query_2(L,R,mid+1,r,rt<<1|1,deep);
else return max(Query_2(L,R,l,mid,rt<<1,deep),Query_2(L,R,mid+1,r,rt<<1|1,deep));
}
float Query(int h1,int h2,int L,int R,int l,int r,int rt) // x轴。一维。
{
if(h1<=l&&h2>=r) return Query_2(L,R,0,1000,1,rt);
int mid=(l+r)>>1;
if(h2<=mid) return Query(h1,h2,L,R,l,mid,rt<<1);
else if(h1>mid) return Query(h1,h2,L,R,mid+1,r,rt<<1|1);
else return max(Query(h1,h2,L,R,l,mid,rt<<1),Query(h1,h2,L,R,mid+1,r,rt<<1|1));
}
int main()
{
int n;
while(~scanf("%d",&n)&&n){
Build(100,200,1);
char ch[5];
while(n--){
scanf("%s",&ch);
if(ch[0]=='I'){
int h;
float x,y;
scanf("%d%f%f",&h,&x,&y);
Insert(h,(int)(x*10),y,100,200,1);
}else{
int h1,h2;
float x1,x2;
scanf("%d%d%f%f",&h1,&h2,&x1,&x2);
//if(h1>h2) swap(h1,h2); // swap函数的使用丢失精度非常严重,得用float才干AC;
//if(x1>x2) swap(x1,x2);
if(h1>h2){ int temp=h1; h1=h2;h2=temp; }
if(x1>x2){ float temp=x1;x1=x2;x2=temp; }
float ans=Query(h1,h2,(int)(x1*10),(int)(x2*10),100,200,1);
if(ans==-1.0) printf("-1\n");
else printf("%.1lf\n",ans);
}
}
}
return 0;
}
HDU1823-Luck and Love-二维线段树(模板)的更多相关文章
- [hdu1823]Luck and Love(二维线段树)
解题关键:二维线段树模板题(单点修改.查询max) #include<cstdio> #include<cstring> #include<algorithm> # ...
- HDU1823 Luck ans Love 二维线段树
Luck and Love HDU - 1823 世界上上最远的距离不是相隔天涯海角 而是我在你面前 可你却不知道我爱你 ―― 张小娴 前段日子,枫冰叶子给Wiskey ...
- hdu1823(二维线段树模板题)
hdu1823 题意 单点更新,求二维区间最值. 分析 二维线段树模板题. 二维线段树实际上就是树套树,即每个结点都要再建一颗线段树,维护对应的信息. 一般一维线段树是切割某一可变区间直到满足所要查询 ...
- hdu 4819 二维线段树模板
/* HDU 4819 Mosaic 题意:查询某个矩形内的最大最小值, 修改矩形内某点的值为该矩形(Mi+MA)/2; 二维线段树模板: 区间最值,单点更新. */ #include<bits ...
- HDU 1823 Luck and Love 二维线段树(树套树)
点击打开链接 Luck and Love Time Limit: 10000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Ot ...
- hdu 1823 Luck and Love 二维线段树
题目链接 很裸的题, 唯一需要注意的就是询问时给出的区间并不是l<r, 需要判断然后交换一下, WA了好多发... #include<bits/stdc++.h> using nam ...
- Luck and Love(二维线段树)
Luck and Love Time Limit: 10000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Tota ...
- HDU1832 二维线段树求最值(模板)
Luck and Love Time Limit: 10000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Tota ...
- HDU 4819 Mosaic (二维线段树&区间最值)题解
思路: 二维线段树模板题,马克一下,以后当模板用 代码: #include<cstdio> #include<cmath> #include<cstring> #i ...
- UVA 11297 Census ——二维线段树
[题目分析] 二维线段树模板题目. 简直就是无比的暴力.时间复杂度为两个log. 标记的更新方式比较奇特,空间复杂度为N^2. 模板题目. [代码] #include <cstdio> # ...
随机推荐
- [YC703]ゴミ拾い Easy
[YC703]ゴミ拾い Easy 题目大意: 二维平面内有\(n(n\le3\times10^5)\)个人和\(n\)个物品,第\(i\)个人在\((a_i,0)\)上,第\(i\)个物品在\((x_ ...
- Unity快捷键总结
Shift+Alt+A 物体快速激活 Ctrl+P 开始 Ctrl+Shift+P 暂停 Ctrl+B 编译并运行 Z Pivot/Center切换 X Local/Global切换
- 微信小程序缓存滑动距离,当页面浏览到一定位置,滑动其他页面后返回该页面记录之前的滑动距离
15.微信小程序缓存滑动距离 我们在浏览页面的时候,然后左滑或者右滑到新的页面,等返回此页面,我们希望可以记录上次滑动的距离 虽然这个实现起来并不难,但是会遇到一些坑,因为scroll-view的组件 ...
- Visual Studio 2015创建Shared Project时出错
今天使用Visual Studio 2015创建共享项目的时候发现如下错误: 网上搜了一下,发现了同样有人问这个问题的问题:Why can't I create Shared Project in V ...
- HDU 4686 Arc of Dream (2013多校9 1001 题,矩阵)
Arc of Dream Time Limit: 2000/2000 MS (Java/Others) Memory Limit: 65535/65535 K (Java/Others)Tota ...
- FreeRTOS Customisation -- FreeRTOSConfig.h
http://www.freertos.org/a00110.html FreeRTOS is customised using a configuration file called FreeRTO ...
- 菜鸟学Java(二十)——你知道long和Long有什么差别吗?
Java中数据类型分两种: 1.基本类型:long,int,byte,float,double2.对象类型:Long,Integer,Byte,Float,Double其他一切java提供的,或者你自 ...
- .NET:命令行解析器介绍
背景 经常需要开发一下小工具,之前都是自己解析命令行参数,接触过动态语言社区以后,发现命令行解析有特定的模式和框架可以利用,本文介绍一个 .NET 平台的类库. 示例 需求 拷贝文件,如:CopyFi ...
- 2009年末最强梅麻呂3D动画游戏大作 汉化补丁
[游戏名称]:Yin荡游戯Ω(前编)-闇の眷族vs女ドラゴン- (名字请自己补) [游戏厂商]:梅麻吕3D [发售日期]:2010年04月16日 游戏评价: 梅麻呂的3D作品能够说是如今3D动画中最好 ...
- (重置adb.exe)android关于The connection to adb is down, and a severe error has occured.这个问题的解决办法
转自:http://www.sjsjw.com/kf_mobile/article/3_24710_14072.asp 这里补充一个更简单的方法(和下面的方法一样的效果): 有时在打开模拟器的时候会出 ...