题目大意:

  这题不好描述,直接看原题吧……

题解:

  很无脑的题……就是卡精度+难写。代码能力还是太差了。

  其实可以直接用long double肝过去。但我的代码似乎太丑了,以至于跑得奇慢无比。

代码:

  

#include "bits/stdc++.h"

using namespace std;

inline int read() {
int s=0,k=1;char ch=getchar();
while (ch<'0'|ch>'9') ch=='-'?k=-1:0,ch=getchar();
while (ch>47&ch<='9') s=s*10+(ch^48),ch=getchar();
return s*k;
} #define double long double const double eps=1e-10; const int N=1e4+10; inline int dcmp(double a) {
if (a>eps) return 1;
if (a<-eps) return -1;
return 0;
} struct P{
P(double _x=0.0,double _y=0.0):x(_x),y(_y){}
double x,y;
double &operator [] (int k) {return k?y:x;}
friend bool operator <(P a,P b) {
return dcmp(a[0]-b[0])==-1||(dcmp(a[0]-b[0])==0&&dcmp(a[1]-b[1])==-1);
}
friend double operator *(P a,P b) {
return a[0]*b[1]-b[0]*a[1];
}
friend P operator /(P a,double b) {
return P(a[0]/b,a[1]/b);
}
friend P operator + (P a,P b) {
return P(a[0]+b[0],a[1]+b[1]);
}
friend P operator * (P a,double b) {
return P(a[0]*b,a[1]*b);
}
friend double operator /(P a,P b) {
return a[0]*b[0]+b[1]*a[1];
}
inline double leth(){
return sqrt(x*x+y*y);
}
};
P operator -(P a,P b) {
return P(a[0]-b[0],a[1]-b[1]);
} struct L{
L(){}L(P _a,P _b):a(_a),b(_b),c(_b-_a),slope(atan2((a-b)[1],(a-b)[0])){}
P a,b,c;double slope;
P &operator[] (int k) {
if(!k) return a;
if (k==1) return b;
return c;
}
friend double touying (L x,L y) {
return x[2]/y[2]/(x[2].leth());
}
friend double touying (L x,P y) {
return x[2]/(y-x[0])/(x[2].leth());
}
friend bool operator <(L x,L y) {
double pos = max (x[0][0],y[0][0]);
return dcmp(fabs(x[0][1] + x[2][1] * (pos-x[0][0]) / ( x[1][0] - x[0][0] )) -
fabs(y[0][1] + y[2][1] * (pos-y[0][0]) / ( y[1][0] - y[0][0] )) ) == -1; }
}block[N],gui; inline bool Judge(L a,L b) {
return dcmp(b[2]*(a[0]-b[0]))==1;
} inline double dis(P p,L l) {
return l[2]*(p-l[0])/l[2].leth();
} double lft[N],lth[N],rght[N],rth[N]; int n,leth,m;
int pl[N],pr[N]; struct node {
P pos;int id;
friend bool operator <(node a,node b) {
return a.pos<b.pos;
}
}np[N*6]; set<L> up,down; double res[N*6]; inline double calc (double x2,double x1,L l) { P delta=l[2]*(x2-x1)/l[2][0];
return delta.leth();
} int main(){ int T=read(); register int i,j;
while (T-- ) {
n=read();
for (i=1;i<=n;++i) {
double x1=read(),y1=read(),x2=read(),y2=read();
if (x1>x2) swap(x1,x2),swap(y1,y2);
if (x1==x2&&y1>y2) swap(y1,y2);
block[i]=L(P(x1,y1),P(x2,y2));
}
double x1=read(),y1=read(),x2=read(),y2=read();leth=read();
if (x1>x2) swap(x1,x2),swap(y1,y2);
if (x1==x2&&y1>y2) swap(y1,y2);
gui=L(P(x1,y1),P(x2,y2));
m=0;
for (i=1;i<=n;++i) {
P a=block[i][0],b=block[i][1];
P na,nb;
na[0] = touying(gui,a),na[1] = dis(a,gui);
nb[0] = touying(gui,b),nb[1] = dis(b,gui);
if (nb<na) swap(na,nb);
block[i] = L(na,nb);
np[++m] = (node){na,i} ;
np[++m] = (node){nb,-i} ;
np[++m] = (node){P (na[0]+leth,na[1]),0};
np[++m] = (node){P (nb[0]+leth,nb[1]),0};
np[++m] = (node){P (na[0]-leth,na[1]),0};
np[++m] = (node){P (nb[0]-leth,nb[1]),0};
}
sort(np+1,np+m+1);
up.clear();
down.clear();
double ans = 0.0,tmp,ret=0.0;
j=1;
while (j<=6*n) {
if (np[j].id<0) {
if (block[-np[j].id][0][1]<-eps)
down.erase(block[-np[j].id]);
else up.erase(block[-np[j].id]);
}else if (np[j].id>0){
if (block[np[j].id][0][1]<-eps)
down.insert(block[np[j].id]);
else up.insert(block[np[j].id]);
}
++j;
res[j]=0.0;
if (up.size()){
tmp = calc (np[j].pos[0],np[j-1].pos[0],*up.begin());
res[j] +=tmp;
}
if (down.size()) {
tmp = calc (np[j].pos[0],np[j-1].pos[0],*down.begin());
res[j] +=tmp;
}
}
for (i=j=1;i<=6*n&&j<=6*n;++i,ans-=res[i]) {
while (j<=6*n&&dcmp(np[j].pos[0]-np[i].pos[0]-leth)<=0) ans+=res[j++];
ret=max(ret,ans);
}
printf("%.15Lf\n",ret);
}
}

  

「SDOI2018」物理实验的更多相关文章

  1. loj#2565. 「SDOI2018」旧试题(反演 三元环计数)

    题意 题目链接 Sol 神仙反演题.在洛谷上疯狂被卡常 Orz shadowice #include<bits/stdc++.h> #define Pair pair<int, in ...

  2. 【LOJ】#2562. 「SDOI2018」战略游戏

    题解 圆方树建好之后点是原来的两倍,而st表求lca也要开到点的两倍,所以是四倍 我并没有开小,然而= =,我的预处理log2,写成了200000,而不是400000 我是不是折翼啊= = 很可写,我 ...

  3. LOJ2476. 「2018 集训队互测 Day 3」蒜头的奖杯 & LOJ2565. 「SDOI2018」旧试题(莫比乌斯反演)

    题目链接 LOJ2476:https://loj.ac/problem/2476 LOJ2565:https://loj.ac/problem/2565 题解 参考照搬了 wxh 的博客. 为了方便, ...

  4. [SDOI2018]物理实验 set,扫描线,旋转坐标系

    [SDOI2018]物理实验 set,扫描线,旋转坐标系 链接 loj 思路 先将导轨移到原点,然后旋转坐标系,参考博客. 然后分线段,每段的贡献(三角函数值)求出来,用自己喜欢的平衡树,我选set. ...

  5. 不设目标也能通关「马里奥」的AI算法,全靠好奇心学习

    在强化学习中,设计密集.定义良好的外部奖励是很困难的,并且通常不可扩展.通常增加内部奖励可以作为对此限制的补偿,OpenAI.CMU 在本研究中更近一步,提出了完全靠内部奖励即好奇心来训练智能体的方法 ...

  6. 「MoreThanJava」一文了解二进制和CPU工作原理

    「MoreThanJava」 宣扬的是 「学习,不止 CODE」,本系列 Java 基础教程是自己在结合各方面的知识之后,对 Java 基础的一个总回顾,旨在 「帮助新朋友快速高质量的学习」. 当然 ...

  7. 「2014-2-6」TokuMX and MongoDB related materials collection

    简介参考 TokuMX 和 MongoDB 各自的官方站点.       ##  Tokutek 最重要的特点和 marketing word 是所谓 fractal tree indexing te ...

  8. Linux 小知识翻译 - 「分区」

    安装Linux的时候,需要对硬盘进行分区.那么「分区」到底是什么呢? 「分区」在日语中有区分,分割的意思.计算机术语中有时会说「对一个磁盘进行分区」,整个意思就是指定如何分割磁盘的意思. 「对磁盘进行 ...

  9. 「Python」socket指南

    开始 网络中的 Socket 和 Socket API 是用来跨网络的消息传送的,它提供了 进程间通信(IPC) 的一种形式.网络可以是逻辑的.本地的电脑网络,或者是可以物理连接到外网的网络,并且可以 ...

随机推荐

  1. 完整的treeview菜单实例

    以下是我用treeview控件按部门和员工显示设备领用情况代码. Option Compare Database    Dim rec As New ADODB.Recordset    Dim re ...

  2. sublime使用技巧之集成VI

    熟悉开发工具,减少多余的操作流程有助于提高开发效率,而Sublime Text 2是sublime产品的经典版本,因此本文基于Sublime Text 2讲解sublime的使用技巧. VI的主要作用 ...

  3. Day11 数据库的基本语法(偏重于查询)

    数据库的介绍: 老师博客: MYSQL-1 - Yuan先生 - 博客园 http://www.cnblogs.com/yuanchenqi/articles/7269675.html 作业地址: h ...

  4. 【精解】EOS标准货币体系与源码实现分析

    EOS智能合约中包含一个exchange合约,它支持用户创建一笔交易,是任何两个基本货币类型之间的交易.这个合约的作用是跨不同币种(都是EOS上的标准货币类型)的,通过各自与EOS主链价值进行锚定,然 ...

  5. nginx 反向代理,支持跨域,前后分离

    前端开发往往涉及到跨域问题,其中解决方案很多: 1.jsonp 需要目标服务器配合一个callback函数. 2.window.name+iframe 需要目标服务器响应window.name. 3. ...

  6. python---生成器、迭代器

    # -*- coding:utf-8 -*- # LC # 列表生成式 def func(x): print(x) return 2*x print([ func(i) for i in range( ...

  7. Android Studio 2.3 instant run与miui冲突问题的解决

    Android Studio最近发布的2.3版本,由于这个版本改进后的Instant Run功能和很多国内ROM存在兼容问题,所以导致不得不做一些妥协策略,具体在小米Rom上,就是把小米rom的调试定 ...

  8. php进阶篇

    字符串调用: $name = 'eco'; echo $name; //eco //双引号会解析变量 echo "$name"; //eco //单引号不会解析变量 echo '$ ...

  9. SOFA 源码分析 — 自动故障剔除

    前言 集群中通常一个服务有多个服务提供者.其中部分服务提供者可能由于网络,配置,长时间 fullgc ,线程池满,硬件故障等导致长连接还存活但是程序已经无法正常响应.单机故障剔除功能会将这部分异常的服 ...

  10. kaggle入门项目:Titanic存亡预测 (一)比赛简介

    自从入了数据挖掘的坑,就在不停的看视频刷书,但是总觉得实在太过抽象,在结束了coursera上Andrew Ng 教授的机器学习课程还有刷完一整本集体智慧编程后更加迷茫了,所以需要一个实践项目来扎实之 ...