poj 2451 Uyuw's Concert
【题目描述】
Remmarguts公主成功地解决了象棋问题。作为奖励,Uyuw计划举办一场音乐会,地点是以其伟大的设计师Ihsnayish命名的巨大广场。
这个位于自由三角洲联合王国(UDF,United Delta of Freedom)最繁华地带的广场是一个坐标范围[0,10000]*[0,10000]的正方形。有一些长椅已经固定在广场上许多年了,但是杂乱无章。见下图:

我们有三张长椅,并且观众面对的方向已经用箭头画出。这些椅子年代久远,并且沉重得无法移动。Remmarguts公主让广场现在的主人UW先生在广场上修建一个大的舞台。这个舞台应当尽可能大,但必须确保在任意长椅上任意位置的观众不必转身就能看到舞台(也就是说舞台必须在长椅所在直线的观众朝向那一侧)。
为了简化问题,舞台的高度可以任意高来确保只要你面向舞台所在的那一侧,你就能看到舞台上的歌唱家/画家——Uyuw,即使你的面前有数千张长椅。
作为一名脑残粉,你能告诉他们舞台的最大面积吗?
【输入格式】
输入包含不超过10组数据。
每组数据格式如下:
第一行有一个整数N(N<=20000),代表长椅的数量。
接下来有N行,每行有4个整数x1,y1,x2,y2,代表一张长椅。这张长椅是以(x1,y1)和(x2,y2)为端点的线段,并且面向其左侧。一个点(x,y)在线段左侧是指(x-x1)*(y-y2)-(x-x2)*(y-y1)>=0.
【输出格式】
对每组数据输出一个一个实数,即舞台的最大面积。精确到1位小数。你的答案被认为是正确的当且仅当它与标准答案之差小于0.2。
【样例输入】
3
10000 10000 0 5000
10000 5000 5000 10000
0 5000 5000 0
【样例输出】
54166666.7
【提示】
样例如下:

建议你采用Pascal中的Extended类型或者C/C++中的long double类型来避免精度误差。不过标程仅仅用了double。
半平面交模板(太坑了)
#include<iostream>
#include<cstdio>
#include<cstring>
#include<cmath>
#include<algorithm>
using namespace std;
typedef double ld;
struct point
{
ld x,y;
point(){}
point(ld _x,ld _y) {x=_x,y=_y;}
}p[];
struct Line
{
point a,b;
ld angle;
Line(){}
Line(point _a,point _b) {a=_a,b=_b;}
}line[],sta[];
ld eps=1e-,ans;
int n,cnt;
point operator -(point a,point b)
{
return point(a.x-b.x,a.y-b.y);
}
int dcmp(ld x)
{
if (x>eps) return ;
if (x<-eps) return -;
return ;
}
ld cross(point a,point b)
{
return a.x*b.y-a.y*b.x;
}
ld getangle(Line l)
{
return atan2(l.b.y-l.a.y,l.b.x-l.a.x);
}
point inter(Line u,Line v)
{
double k1=(cross((u.b-v.a),(v.b-v.a)));
double k2=(cross((v.b-v.a),(u.a-v.a)));
double t=k1/(k1+k2);
return point(u.b.x+(u.a.x-u.b.x)*t,u.b.y+(u.a.y-u.b.y)*t);
}
bool cmp(Line u,Line v)
{
int t=dcmp(u.angle-v.angle);
if (t) return t<;
return dcmp(cross(u.a-v.b,v.a-v.b))>;
}
bool judge(Line a,Line b,Line c)
{
point p=inter(b,c);
return dcmp(cross(a.a-p,a.b-p))<;
}
void HPT()
{int i,head,tail;
sort(line+,line+n+,cmp);
int tmp=;
for (i=;i<=n;i++)
if (dcmp(line[i].angle-line[i-].angle)!=)
line[++tmp]=line[i];
n=tmp;
head=,tail=;
sta[]=line[];sta[]=line[];
for (i=;i<=n;i++)
{
while (tail->=head&&judge(line[i],sta[tail],sta[tail-])) tail--;
while (head+<=tail&&judge(line[i],sta[head+],sta[head])) head++;
tail++;
sta[tail]=line[i];
}
while (tail->=head&&judge(sta[head],sta[tail],sta[tail-])) tail--;
while (head+<=tail&&judge(sta[tail],sta[head+],sta[head])) head++;
cnt=;
if (tail-head<=) return;
for (i=head;i<tail;i++)
{
p[++cnt]=inter(sta[i],sta[i+]);
}
if (tail>head+)
p[++cnt]=inter(sta[head],sta[tail]);
}
int main()
{
int i;
while (cin>>n)
{
n+=;
line[]=Line(point(,),point(,));
line[]=Line(point(,),point(,));
line[]=Line(point(,),point(,));
line[]=Line(point(,),point(,));
line[].angle=getangle(line[]);
line[].angle=getangle(line[]);
line[].angle=getangle(line[]);
line[].angle=getangle(line[]);
for (i=;i<=n;i++)
{
scanf("%lf%lf%lf%lf",&line[i].a.x,&line[i].a.y,&line[i].b.x,&line[i].b.y);
line[i].angle=getangle(line[i]);
}
HPT();
ans=;
for (i=;i<cnt;i++)
{
ans+=cross(p[i]-p[],p[i+]-p[])/2.0;
}
ans=fabs(ans);
printf("%.1lf\n",ans);
}
return ;
}
poj 2451 Uyuw's Concert的更多相关文章
- poj 2451 Uyuw's Concert (半平面交)
2451 -- Uyuw's Concert 继续半平面交,这还是简单的半平面交求面积,不过输入用cin超时了一次. 代码如下: #include <cstdio> #include &l ...
- POJ 2451 Uyuw's Concert (半平面交)
题目链接:POJ 2451 Problem Description Prince Remmarguts solved the CHESS puzzle successfully. As an awar ...
- poj 2451 Uyuw's Concert(半平面交)
Uyuw's Concert Time Limit: 6000MS Memory Limit: 65536K Total Submissions: 8580 Accepted: 3227 De ...
- POJ 2451 Uyuw's Concert(半平面交nlgn)
//#pragma comment(linker, "/STACK:16777216") //for c++ Compiler #include <stdio.h> # ...
- bzoj 2451 Uyuw's Concert
裸的半平面交.感觉这些东西,纯属在考代码能力啊.. #include<cstdio> #include<algorithm> #include<cmath> #de ...
- 计算几何模板 (bzoj 1336,poj 2451 ,poj3968)
poj 3968 (bzoj 2642) 二分+半平面交,每次不用排序,这是几个算几版综合. #include<iostream> #include<cstdio> #incl ...
- POJ2451 Uyuw's Concert(半平面交)
题意就是给你很多个半平面,求半平面交出来的凸包的面积. 半平面交有O(n^2)的算法,就是每次用一个新的半平面去切已有的凸包,更新,这个写起来感觉也不是特别好写. 另外一个O(nlogn)的算法是将半 ...
- Uyuw's Concert POJ2451
裸半平面交,以前没写过,先写一遍再说 我越来越不注意细节了,最后才发现空间稍微开小了(没有开那个零头,他又要多4条边,就WA了) const maxn=; eps=1e-7; type point=r ...
- [poj2451]Uyuw's Concert
半平面交滴裸题,但是要求nlogn,练练手 #include<iostream> #include<cstdio> #include<cmath> #include ...
随机推荐
- MySQL之数据的简单查询
我直接把我的mysql学习笔记以图片的形式粘贴在这里了,供自己回顾(都是一些简单的语句)
- 20162302 实验一《Java开发环境的熟悉》实验报告
实 验 报 告 课程:程序设计与数据结构 姓名:杨京典 班级:1623 学号:20162302 实验名称:Java开发环境的熟悉 实验器材:装有Ubuntu的联想拯救者80RQ 实验目的与要求:1.使 ...
- 20162302 实验三《敏捷开发与XP实践》实验报告
实 验 报 告 课程:程序设计与数据结构 姓名:杨京典 班级:1623 学号:20162302 实验名称:敏捷开发与XP实践 实验器材:装有IdeaU的联想拯救者80RQ 实验目的与要求:1.代码的格 ...
- 团队作业7-Beta版本冲刺计划及安排
a.下一阶段需要改进完善的功能 对部分bug的修改,主要是在未登录时页面跳转的问题以及防止通过对数据库进行注入查询. b.下一阶段新增的功能 1.活动页面,提示打折信息等. 2.商家修改打折信息 3. ...
- Linux学习--线程控制
关于线程控制,主要就是几个模块,我们一个一个消灭.消化: 一.线程创建: 1.先来看看在Linux环境下的线程创建函数: 分析:意思很明显: 1.函数名是 pthread_create : 2.功能 ...
- jQuery函数学习
函数:after(content) 功能:在每个匹配的元素后面添加html内容 返回:jQuery对象 参数:content (<Content>): Content to insert ...
- 构建微服务开发环境3————Java应用的优秀管理工具Maven的下载安装及配置
[内容指引] 下载安装包: MacOS下Maven的安装及配置: Windows下Maven的安装及配置. 一.下载安装包 进入Maven的官方下载地址:http://maven.apache.org ...
- 详解JavaScript对象继承方式
一.对象冒充 其原理如下:构造函数使用 this 关键字给所有属性和方法赋值(即采用类声明的构造函数方式).因为构造函数只是一个函数,所以可使 Parent 构造函数成为 Children 的方法,然 ...
- 剑指offer-二叉树中和为某一值的路径
题目描述 输入一颗二叉树和一个整数,打印出二叉树中结点值的和为输入整数的所有路径.路径定义为从树的根结点开始往下一直到叶结点所经过的结点形成一条路径. 解题思路 利用前序遍历的思想,定义FindP ...
- Spring Security入门(3-1)Spring Security的登录页面定制