Luck and Love

HDU - 1823

世界上上最远的距离不是相隔天涯海角 
而是我在你面前 
可你却不知道我爱你 
                ―― 张小娴 

前段日子,枫冰叶子给Wiskey做了个征婚启事,聘礼达到500万哦,天哪,可是天文数字了啊,不知多少MM蜂拥而至,顿时万人空巷,连扫地的大妈都来凑热闹来了。―_―||| 
由于人数太多,Wiskey实在忙不过来,就把统计的事情全交给了枫冰叶子,自己跑回家休息去了。这可够枫冰叶子忙的了,他要处理的有两类事情,一是得接受MM的报名,二是要帮Wiskey查找符合要求的MM中缘分最高值。 

Input本题有多个测试数据,第一个数字M,表示接下来有连续的M个操作,当M=0时处理中止。 
接下来是一个操作符C。 
当操作符为‘I’时,表示有一个MM报名,后面接着一个整数,H表示身高,两个浮点数,A表示活泼度,L表示缘分值。 (100<=H<=200, 0.0<=A,L<=100.0) 
当操作符为‘Q’时,后面接着四个浮点数,H1,H2表示身高区间,A1,A2表示活泼度区间,输出符合身高和活泼度要求的MM中的缘分最高值。 (100<=H1,H2<=200, 0.0<=A1,A2<=100.0)
所有输入的浮点数,均只有一位小数。 
Output对于每一次询问操作,在一行里面输出缘分最高值,保留一位小数。 
对查找不到的询问,输出-1。 
Sample Input

8
I 160 50.5 60.0
I 165 30.0 80.5
I 166 10.0 50.0
I 170 80.5 77.5
Q 150 166 10.0 60.0
Q 166 177 10.0 50.0
I 166 40.0 99.9
Q 166 177 10.0 50.0
0

Sample Output

80.5
50.0
99.9

——————————————————————————————————————————————————————————————————————————

处理二维表格中的数据修改和查询操作,用传说中的二维线段树。

首先第一维为行,把行建立线段树,线段树的节点代表1个到多个行。

然后把行线段树的每个节点对应的列建立线段树,每个节点代表在行节点控制范围内的1个到多个列。

时间负责度为log(m)*log(n),其中m和n代表行数和列数。

另外,还有一种写法,就是建立四叉线段树。也可以称为“矩形树”。实际上就是把矩形按照行和列的二分,分为4块区域。应该更好理解且更好写。只是据说这种写法复杂度有可能退化。

——————————————————————————————————————————————————————————————————————————

  1 #include<bits/stdc++.h>
2 using namespace std;
3 const int maxn=105;
4 const int maxm=1005;
5 struct Lie
6 {
7 int ll,lr;
8 int max;
9 };
10 struct Hang
11 {
12 int l,r;
13 Lie lie[maxm<<2];
14 }hang[maxn<<2];
15 int m,active,love,hight;
16 char s[2];
17 void buil(int hh,int cur,int l,int r)
18 {
19 hang[hh].lie[cur].ll=l;
20 hang[hh].lie[cur].lr=r;
21 hang[hh].lie[cur].max=-1;
22 if(l==r)return ;
23 int mid=(l+r)>>1;
24 buil(hh,cur<<1,l,mid);
25 buil(hh,cur<<1 | 1,mid+1,r);
26 }
27 void build(int cur,int l,int r,int ll,int lr)
28 {
29 hang[cur].l=l;hang[cur].r=r;
30 buil(cur,1,ll,lr);
31 if(l==r)return ;
32 int mid=(l+r)>>1;
33 build(cur<<1,l,mid,ll,lr);
34 build(cur<<1 | 1,mid+1,r,ll,lr);
35 }
36 void upda(int pre,int cur,int hh,int lh,int dat)
37 {
38 if(hang[pre].lie[cur].ll==hang[pre].lie[cur].lr)
39 {
40 hang[pre].lie[cur].max=max(hang[pre].lie[cur].max,dat);
41 return ;
42 }
43 int mid=(hang[pre].lie[cur].ll+hang[pre].lie[cur].lr)>>1;
44 if(lh<=mid)upda(pre,cur<<1,hh,lh,dat);
45 else upda(pre,cur<<1|1,hh,lh,dat);
46 hang[pre].lie[cur].max=max(hang[pre].lie[cur<<1].max,hang[pre].lie[cur<<1|1].max);
47 }
48 void update(int cur,int hh,int lh,int dat)
49 {
50 upda(cur,1,hh,lh,dat);
51 if(hang[cur].l==hang[cur].r)return;
52 int mid=(hang[cur].l+hang[cur].r)>>1;
53 if(hh<=mid)update(cur<<1,hh,lh,dat);
54 else update(cur<<1|1,hh,lh,dat);
55 }
56 float quer(int pre,int cur,int l1,int l2)
57 {
58 if(l1<=hang[pre].lie[cur].ll && hang[pre].lie[cur].lr<=l2)
59 return hang[pre].lie[cur].max;
60 int mid=(hang[pre].lie[cur].ll + hang[pre].lie[cur].lr)>>1;
61 float ans=-1;
62 if(l1<=mid)ans=max(ans,quer(pre,cur<<1,l1,l2));
63 if(mid<l2)ans=max(ans,quer(pre,cur<<1|1,l1,l2));
64 return ans;
65 }
66 float query(int cur,int h1,int h2,int l1,int l2)
67 {
68 if(h1<=hang[cur].l && hang[cur].r<=h2)return quer(cur,1,l1,l2);
69 int mid=(hang[cur].l+hang[cur].r)>>1;
70 float ans=-1;
71 if(h1<=mid)ans=max(ans,query(cur<<1,h1,h2,l1,l2));
72 if(h2>mid)ans=max(ans,query(cur<<1|1,h1,h2,l1,l2));
73 return ans;
74 }
75 int main()
76 {
77 while(scanf("%d",&m)==1 && m)
78 {
79 build(1,100,200,0,1000);
80 for(int i=0;i<m;i++)
81 {
82 scanf("%s",s);
83 if(s[0]=='I')
84 {
85 int h;
86 float act,lov;
87 scanf("%d%f%f",&h,&act,&lov);
88 active=(int)(10*act);
89 love=(int)(10*lov);
90 update(1,h,active,love);
91 }
92 else
93 {
94 int h1,h2;
95 float a1,a2;
96 scanf("%d%d%f%f",&h1,&h2,&a1,&a2);
97 int aa1=(int)(a1*10);
98 int aa2=(int)(a2*10);
99 if(h1>h2)swap(h1,h2);
100 if(aa1>aa2)swap(aa1,aa2);
101 double ans=query(1,h1,h2,aa1,aa2);
102 if(ans<0)printf("-1\n");
103 else printf("%.1f\n",ans/10);
104 }
105 }
106 }
107 return 0;
108 }

HDU1823 Luck ans Love 二维线段树的更多相关文章

  1. [hdu1823]Luck and Love(二维线段树)

    解题关键:二维线段树模板题(单点修改.查询max) #include<cstdio> #include<cstring> #include<algorithm> # ...

  2. HDU 1823 Luck and Love 二维线段树(树套树)

    点击打开链接 Luck and Love Time Limit: 10000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Ot ...

  3. hdu 1823 Luck and Love 二维线段树

    题目链接 很裸的题, 唯一需要注意的就是询问时给出的区间并不是l<r, 需要判断然后交换一下, WA了好多发... #include<bits/stdc++.h> using nam ...

  4. hdu1823(二维线段树模板题)

    hdu1823 题意 单点更新,求二维区间最值. 分析 二维线段树模板题. 二维线段树实际上就是树套树,即每个结点都要再建一颗线段树,维护对应的信息. 一般一维线段树是切割某一可变区间直到满足所要查询 ...

  5. HDU 1823 Luck and Love(二维线段树)

    之前只知道这个东西的大概概念,没具体去写,最近呵呵,今补上. 二维线段树 -- 点更段查 #include <cstdio> #include <cstring> #inclu ...

  6. Luck and Love(二维线段树)

    Luck and Love Time Limit: 10000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Tota ...

  7. HDU1832 二维线段树求最值(模板)

    Luck and Love Time Limit: 10000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Tota ...

  8. POJ2155 Matrix二维线段树经典题

    题目链接 二维树状数组 #include<iostream> #include<math.h> #include<algorithm> #include<st ...

  9. POJ 2155 Matrix (二维线段树入门,成段更新,单点查询 / 二维树状数组,区间更新,单点查询)

    题意: 有一个n*n的矩阵,初始化全部为0.有2中操作: 1.给一个子矩阵,将这个子矩阵里面所有的0变成1,1变成0:2.询问某点的值 方法一:二维线段树 参考链接: http://blog.csdn ...

随机推荐

  1. SpringBoot 获取微信小程序openid

    最近做一个项目用到小程序,为了简化用户啊登录,通过获取小程序用户的openid来唯一标示用户. 1.官方教程 2.具体步骤 3.具体实现 4.可能出现的错误 5.代码下载 1.官方教程 先来看看官方怎 ...

  2. 智能BPOS小票模板字体的使用

    关于伯俊智能BPOS零售小票模板的设置,常用字体"黑体"."宋体"."Arial"这几个字体,在设置的时候看似没有问题, 但是在正真使用打印 ...

  3. Turtlebot3入门教程-系统-SBC软件设置(ubuntu20.04)

    本文针对如何在树莓派3上安装ubuntu20.04系统和软件进行讲解 树莓派3接上显示屏和鼠标后,开机后继续安装软件包 详细步骤如下: (1)系统安装 (2)ROS安装 (3)TurboBot3依赖的 ...

  4. 容器编排系统K8s之NetworkPolicy资源

    前文我们了解了k8s的网络插件flannel的基础工作逻辑,回顾请参考:https://www.cnblogs.com/qiuhom-1874/p/14225657.html:今天我们来聊一下k8s上 ...

  5. Vue3.0聊天室|vue3+vant3仿微信聊天实例|vue3.x仿微信app界面

    一.项目简介 基于Vue3.0+Vant3.x+Vuex4.x+Vue-router4+V3Popup等技术开发实现的仿微信手机App聊天实例项目Vue3-Chatroom.实现了发送图文表情消息/g ...

  6. 在.NET Core中使用Channel(二)

    在我们之前的文章中,看了一些非常简单的例子来说明Channel是如何工作的,我们看到了一些非常漂亮的特性,但大多数情况下它与其他某某Queue实现非常相似.让我们进入一些更高级的话题.我说的是高级,但 ...

  7. 数仓面试高频考点--解决hive小文件过多问题

    本文首发于公众号:五分钟学大数据 小文件产生原因 hive 中的小文件肯定是向 hive 表中导入数据时产生,所以先看下向 hive 中导入数据的几种方式 直接向表中插入数据 insert into ...

  8. netty服务端客户端启动流程分析

    服务端启动流程 我们回顾前面讲解的netty启动流程,服务端这边有两个EventLoopGroup,一个专门用来处理连接,一个用来处理后续的io事件 服务端启动还是跟nio一样,绑定端口进行监听,我们 ...

  9. ForwardProcess

    共享式网络中,发送的报文所有设备都可以收到 0.0.0.0/0 缺省路由 可以到达任意网络 From WizNote

  10. 【C++】《Effective C++》第五章

    第五章 实现 条款26:尽可能延后变量定义式的出现时间 只要定义了一个变量而其类型带有一个构造函数或析构函数,那么 当程序的控制流到达这个变量定义式时,你得承受这个构造成本. 当这个变量离开这个作用域 ...