hdu3340 线段树+多边形
Rain in ACStar
Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 788 Accepted Submission(s): 218
This is one of the ten biggest secrets of this world! And it is time to expose the truth!
Yes, Super Cow AC is from ACStar which is ten million light-year away from our earth. No one, even AC himself, knows how AC came to our home. The only memory in his head is the strange rain in ACStar.
Because of the special gravity of ACStar, the raindrops in ACStar have many funny features. They have arbitrary sizes, color and tastes. The most interesting parts of the raindrops are their shapes. When AC was very young, he found that all the drops he saw
in air were convex hull. Once the raindrops fell to the ground, they would be absorb by the soil.

This year is set to be AC-year. In recognition of Great General AC's contribution to our empire, the Emperor decided to build a huge AC park. Inside this park there is a laboratory to simulate the rain in ACStar. As a researcher of this lab, you are appointed
to measure the volume of rain absorbed by soil. To simplify this problem, scientists put the rain into two-dimensional plane in which the ground is represented as a straight line and the raindrops are convex polygon. So the area of the graphics stands for
the volume of raindrops.
You will receive two types of instructions:
1.R P (This type of instructions tell you sufficient information about the raindrops.)
2.Q A B (Ask you to report the volume of rain absorbed by soil of [A,B].)
Instructions are given in chronological order.
After T, the inputs will be each test case. The first line of each case will be N(no more than 25000), representing for the numbers of instructions. The following N lines will give instructions of the two types.
For each instruction of type 1, it will be followed by a line listing P (at least 3 and at most 5) points representing the convex polygon of the coming raindrop. The points are started by the leftmost point and are given in counterclockwise order. It's guaranteed
that no points of the same raindrop are in the same vertical line.
All numbers are positive integer no more than 1000000000.
It is guaranteed that the result is less than 1e8.
7
Q 1 100
R 4
10 10 11 10 13 11 12 11
Q 10 11
Q 1 100
R 3
100 20 120 20 110 30
Q 1 100
Q 12 120
0.250
1.000
1.000
100.250
/*
hdu3340 线段树+多边形
R x:表示在这有个x边形
Q l r:查询在[l,r]之间的多边形的面积 所以考虑用线段树解决,那么我们就要知道如何处理区间的面积,对于一个多边形,
它的每一条边都可以在两端作垂直于x轴的垂线然后形成一个梯形,于是用图形
上半部分的边形成的梯形和- 半部分的边形成的梯形和便能得到多边形面积。
而且两个同高的梯形的面积和等同于上底和下底的叠加 hhh-2016-03-02 20:54:04 Accepted
*/
#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <algorithm>
#include <cmath>
#include <map>
#include <queue>
#include <vector>
using namespace std;
typedef long long ll;
typedef long double ld;
const int maxn = 500200;
map<int,int>has;
vector<int> tp;
char op[10]; struct node
{
int l,r;
int mid()
{
return l+(r-l)/2;
}
double h1,h2,k,len;
double area;
} tree[maxn]; void push_up(int r)
{
tree[r].area = tree[r<<1].area+tree[r<<1|1].area;
} void build(int i,int l,int r)
{
tree[i].l = l,tree[i].r = r;
tree[i].h1 = tree[i].h2 = tree[i].k = tree[i].area = 0;
tree[i].len = tp[r]-tp[l];
if(l == r) return;
if(l+1 != r)
{
build(i<<1,l,tree[i].mid());
build(i<<1|1,tree[i].mid(),r);
push_up(i);
}
} void push_down(int i)
{
int lson = i<<1,rson =i<<1|1;
double h1=tree[i].h1,h2=tree[i].h2,k=tree[i].k;
double md = (tp[tree[i].mid()]-tp[tree[i].l])*k+h1; tree[lson].h1+=h1,tree[lson].h2+=md,tree[lson].k+=k;
tree[lson].area += (h1+md)*tree[lson].len/2; tree[rson].h1+=md,tree[rson].h2+=h2,tree[rson].k+=k;
tree[rson].area += (md+h2)*tree[rson].len/2; tree[i].h1 = tree[i].h2 = tree[i].k = 0;
} void update(int i,int l,int r,double h1,double h2,double k)
{
if(tree[i].l >= l && tree[i].r <= r)
{
tree[i].h1+=h1,tree[i].h2+=h2,tree[i].k+=k;
tree[i].area += (h1+h2)*tree[i].len/2;
return ;
}
push_down(i);
double md= (tp[tree[i].mid()]-tp[l])*k+h1;
if(r <= tree[i].mid())
update(i<<1,l,r,h1,h2,k);
else if(l >= tree[i].mid())
update(i<<1|1,l,r,h1,h2,k);
else
{
update(i<<1,l,tree[i].mid(),h1,md,k);
update(i<<1|1,tree[i].mid(),r,md,h2,k);
}
push_up(i);
} double query(int i,int l,int r)
{
if(tree[i].l >= l && tree[i].r <= r)
{
return tree[i].area;
}
push_down(i);
double ans = 0;
if(l < tree[i].mid())
ans += query(i<<1,l,r);
if(tree[i].mid() < r)
ans += query(i<<1|1,l,r);
push_up(i);
return ans;
} struct point
{
int x[6],y[6];
int num;
void get()
{
num = 0;
scanf("%s",op);
if(op[0] == 'R')
{
scanf("%d",&num);
for(int i = 0; i < num; i++)
{
scanf("%d%d",&x[i],&y[i]);
tp.push_back(x[i]);
}
}
else
{
scanf("%d%d",&x[1],&y[1]);
tp.push_back(x[1]);
tp.push_back(y[1]);
}
}
} Point[50010]; int main()
{
int T;
scanf("%d",&T);
while(T--)
{
int n;
tp.clear(),has.clear();
scanf("%d",&n);
for(int i =1;i <= n;i++)
{
Point[i].get();
} sort(tp.begin(),tp.end());
tp.erase(unique(tp.begin(),tp.end()),tp.end());
for(int i = 0;i < (int)tp.size();i++)
has[tp[i]] = i;
build(1,0,tp.size()-1);
for(int i =1;i <= n;i++)
{
if(Point[i].num)
{
for(int j = 0;j < Point[i].num;j++)
{
int num = Point[i].num;
int x1=Point[i].x[j],y1=Point[i].y[j];
int x2=Point[i].x[(j+1)%num],y2=Point[i].y[(j+1)%num];
if(x1 > x2)swap(x1,x2),swap(y1,y2);
else y1=-y1,y2=-y2;
double k = (1.0*y1-1.0*y2)/(1.0*x1-1.0*x2);
update(1,has[x1],has[x2],y1,y2,k);
// printf("%.3f\n",query(1,has[1],has[100]));
}
}
else
{
int x = Point[i].x[1];
int y = Point[i].y[1];
printf("%.3f\n",query(1,has[x],has[y]));
}
}
}
return 0;
}
hdu3340 线段树+多边形的更多相关文章
- 线段树总结 (转载 里面有扫描线类 还有NotOnlySuccess线段树大神的地址)
转载自:http://blog.csdn.net/shiqi_614/article/details/8228102 之前做了些线段树相关的题目,开学一段时间后,想着把它整理下,完成了大牛NotOnl ...
- [转载]完全版线段树 by notonlysuccess大牛
原文出处:http://www.notonlysuccess.com/ (好像现在这个博客已经挂掉了,在网上找到的全部都是转载) 今天在清北学堂听课,听到了一些很令人吃惊的消息.至于这消息具体是啥,等 ...
- 【转】线段树完全版~by NotOnlySuccess
线段树完全版 ~by NotOnlySuccess 很早前写的那篇线段树专辑至今一直是本博客阅读点击量最大的一片文章,当时觉得挺自豪的,还去pku打广告,但是现在我自己都不太好意思去看那篇文章了,觉 ...
- [IOI2018]排座位——线段树
题目链接: IOI2018seat 题目大意:给出一个$H*W$的矩阵,将$0 \sim W*H-1$分别填入矩阵的格子里(每个格子里一个数),定义一个子矩阵是美妙的当且仅当这个子矩阵包含且仅包含$0 ...
- HDU 1542 - Atlantis - [线段树+扫描线]
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1542 Time Limit: 2000/1000 MS (Java/Others) Memory Li ...
- 《完全版线段树》——notonlysuccess
转载自:NotOnlySuccess的博客 [完全版]线段树 很早前写的那篇线段树专辑至今一直是本博客阅读点击量最大的一片文章,当时觉得挺自豪的,还去pku打广告,但是现在我自己都不太好意思去看那篇文 ...
- 【转】 线段树完全版 ~by NotOnlySuccess
载自:NotOnlySuccess的博客 [完全版]线段树 很早前写的那篇线段树专辑至今一直是本博客阅读点击量最大的一片文章,当时觉得挺自豪的,还去pku打广告,但是现在我自己都不太好意思去看那篇文章 ...
- 【转载】完全版线段树 by notonlysuccess大牛
原文出处:http://www.notonlysuccess.com/ 今晚上比赛就考到了 排兵布阵啊,难受. [完全版]线段树 很早前写的那篇线段树专辑至今一直是本博客阅读点击量最大的一片文章,当时 ...
- HDU 3340 Rain in ACStar(线段树+几何)
HDU 3340 Rain in ACStar pid=3340" target="_blank" style="">题目链接 题意:给定几个多 ...
随机推荐
- LeetCode & Q27-Remove Element-Easy
Array Two Pointers Description: Given an array and a value, remove all instances of that value in pl ...
- 20165230 2017-2018-2 《Java程序设计》第4周学习总结
20165230 2017-2018-2 <Java程序设计>第4周学习总结 教材学习内容总结 子类与继承 通过class 子类名 extends 父类名定义子类.子类只能继承一个父类,关 ...
- MyEclipse的多模块Maven web(ssm框架整合)
Maven的多模块可以让项目结构更明确,提高功能的内聚,降低项目的耦合度,真正的体现出分层这一概念. 我们在操作中,要明白为什么这样做,要了解到更深的层次,这样,我们就不限于个别软件了. 话不多说,直 ...
- 数据库“行专列”操作---使用row_number()over(partition by 分组字段 [order by 排序字段])
测试样例: create table test(rsrp string,rsrq string,tkey string,distan string); '); '); '); '); select * ...
- 南京邮电大学java程序设计作业在线编程第二次作业
王利国的"Java语言程序设计第2次作业(2018)"详细 作业结果详细 总分:100 选择题得分:60 1. 表达式9==8&&3<7的运算结果是( ) ...
- hdu 6095 Rikka with Competition---思维题贪心
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=6095 题目大意: 任意两个人相比,相差大于K,分低的淘汰,否则两人都有可能赢,剩下的继续比,问有最多 ...
- ecshop PC版本智能跳转到对应手机版页面
以下适用于PC跳转到ectouch手机版的写法.其他手机端的方法类似. 修改文件 includes/lib_main.php 增加以下 1 2 3 4 5 6 7 8 9 10 11 12 13 14 ...
- spring boot / cloud (四) 自定义线程池以及异步处理@Async
spring boot / cloud (四) 自定义线程池以及异步处理@Async 前言 什么是线程池? 线程池是一种多线程处理形式,处理过程中将任务添加到队列,然后在创建线程后自动启动这些任务.线 ...
- Unity中的基础光照
渲染包含了两大部分:决定一个像素的可见性,决定这个像素上的光照计算. 光照模型就是用于决定在一个像素上进行怎样的光照计算. 一.光源 在实时渲染中我们通常把光源当做一个没有体积的点. 1.1 辐照度 ...
- 关于python 使用腾讯云OCR 通用印刷体识别
腾讯的python SDK没有通用印刷体识别,所以参考了别人识别网上图片的方式:https://www.cnblogs.com/semishigure/p/7690789.html 但是咱们使用的基本 ...