SDOI2018 物理实验

SDOI2018 物理实验

题意:二维平面上有一条直线,直线上放置了一个激光发射器,会向导轨两侧沿导轨垂直方向发射宽度为 L 的激光束。平面上还有 n 条线段,并且线段和线段、线段和直线之间都没有公共点,线段和直线的夹角不超过 85◦,激光束不能穿透线段,你需要求出激光束能照射到的线段长度之和的最大值。
做法:先进行坐标变换,将给定直线移到x轴上,注意首先将直线的一端移到原点,然后再旋转。(样例数据全都从原点出发。。。没发现。就gg了十几发,好脑残啊。。)考虑将每个线段投影到直线上,这些点将直线分成一些线段,对于每一段,找到它上方最近的那个线段,然后计算单位长度的贡献,最后的答案就可以双指针求出了。对于查询上方最近的线段,使用set维护扫描线即可。双指针还写崩了。。。这题出出来就gg了啊。。。码力弱炸,还手残。

#include <bits/stdc++.h>
using namespace std;
#define rep(i,a,b) for(int i=(a);i<=(b);++i)
#define per(i,a,b) for(int i=(a);i>=(b);--i)
#define pb push_backtypedef long double db;const db EPS = 0;
const db INF = 1e100;
inline int sgn(db x, db E = EPS){return x<-E?-1:x>E;}
inline int cmp(db a,db b,db E = EPS){return sgn(a-b, E);}struct P{db x,y;bool operator<(P o) const { return cmp(x,o.x) != 0? cmp(x,o.x) == -1 : cmp(y,o.y) == -1; }bool operator>(P o) const { return cmp(x,o.x) != 0? cmp(x,o.x) == 1 : cmp(y,o.y) == 1; }bool operator==(P o) { return cmp(x,o.x) == 0 && cmp(y,o.y) == 0; }void read(){ int _x,_y; scanf("%d%d",&_x,&_y); x=_x,y=_y; }P operator + (P o) { return {x+o.x,y+o.y}; }P operator - (P o) { return {x-o.x,y-o.y}; }db det(P o) { return x*o.y-y*o.x; }db dot(P o){ return x*o.x+y*o.y; }db disTo(P p) { return (*this - p).abs(); }db alpha() { return atan2(y, x); }db abs() { return sqrt(abs2());}db abs2() { return x * x + y * y; }P rot(db a) {db c = cos(a), s = sin(a);return {c*x-s*y, s*x+c*y};}
};struct L {P ps[2];L(){}L(P p1, P p2) { ps[0] = p1, ps[1] = p2; }P& operator[](int i) { return ps[i]; }P dir() { return ps[1] - ps[0]; }bool include(P p) { return sgn((ps[1]-ps[0]).det(p-ps[0])); }
};db nowx = 0;
int top[100010];
vector<db> scan;
int sc;struct seg {P u, v; int id; db k;seg(){}seg(P _u, P _v, int _id) {id = _id; u = _u; v = _v;k = (v.y - u.y) / (v.x - u.x);}bool operator < (const seg a) const {db v1 = u.y + k * (nowx - u.x);db v2 = a.u.y + a.k * (nowx - a.u.x);if( cmp(v1, v2) == 0 ) return k < a.k;return v1 < v2;}
};
set< seg > S;
set< seg >::iterator it[100010];struct Q {P e; int id;bool operator < (Q a) {if(e == a.e) return id < a.id;return e < a.e;}
};
vector< Q > qs;
vector<db> cal(vector<L> ls) {int n = ls.size();qs.clear();rep(i,0,n-1) {if(ls[i][0].x > ls[i][1].x) swap(ls[i][0], ls[i][1]);qs.pb({ls[i][0], -i-1});qs.pb({ls[i][1], i+1});}sort(qs.begin(),qs.end());nowx = 0; S.clear();rep(i,0,sc-1) top[i] = -1;for(int j = 0, i = 0; i < sc; ++ i) {nowx = scan[i];for( ; j < qs.size() && qs[j].e.x <= nowx ; ++j) {if(qs[j].id < 0) {int ID = (-qs[j].id)-1;it[ID] = S.insert(seg(ls[ID][0],ls[ID][1],ID)).first;}else {int ID = qs[j].id-1;S.erase(it[ID]);}}if(!S.empty()) top[i] = (*S.begin()).id;}function<db(int)> cost = [&](int tp) -> db {return abs( ls[tp][0].disTo(ls[tp][1]) / (ls[tp][1].x - ls[tp][0].x) );};vector<db> V;rep(i, 0, sc-2) {if(top[i] != -1) V.pb(cost(top[i])); else V.pb(0);}return V;
}db pv[100010], pc[100010];db cala(vector< pair<db,db> > &V, db Len) {function<db(db,int,int)> MX = [&](db LL, int p1, int p2) -> db {db tmp = 0;if(0 <= p1 && p1 <= sc-2) tmp = max(tmp, V[p1].second * min(LL, V[p1].first) );if(0 <= p2 && p2 <= sc-2) tmp = max(tmp, V[p2].second * min(LL, V[p2].first) );return tmp;};db ans = 0;int p1 = 0, p2 = 0; db tC = 0, tL = 0;do {if(Len >= tL) ans = max(ans, tC + MX(Len-tL, p1-1, p2 ) );if(p2 < sc-1 && cmp(tL + V[p2].first, Len) <= 0) {tL += V[p2].first;tC += V[p2].first * V[p2].second;++ p2;}else if(p1 <= p2) {tL -= V[p1].first;tC -= V[p1].first * V[p1].second;++ p1;}else {if(p2 < sc-1) {tL += V[p2].first;tC += V[p2].first * V[p2].second;++ p2;}if(p1 <= p2) {tL -= V[p1].first;tC -= V[p1].first * V[p1].second;++ p1;}}if(Len >= tL) ans = max(ans, tC + MX(Len-tL, p1-1, p2 ) );} while(p1 < sc-1 || p2 < sc-1);return ans;
}int n;
L line[100010];
P p1, p2;
db Len;
vector<L> UP, LW;void init() {UP.clear(); LW.clear();if(p1 > p2) swap(p1, p2);db a = -(p2-p1).alpha();rep(i,0,n-1) {line[i][0] = (line[i][0]-p1).rot(a);line[i][1] = (line[i][1]-p1).rot(a);if( sgn(line[i][0].y) == 1 ) UP.pb(line[i]);else LW.pb( L( {line[i][0].x, -line[i][0].y} , {line[i][1].x, -line[i][1].y} ) );}scan.clear();rep(i,0,(int)UP.size()-1) { scan.pb(UP[i][0].x), scan.pb(UP[i][1].x); }rep(i,0,(int)LW.size()-1) { scan.pb(LW[i][0].x), scan.pb(LW[i][1].x); }sort(scan.begin(),scan.end()); scan.erase( unique(scan.begin(),scan.end()), scan.end());sc = scan.size();
}int main() {int _; scanf("%d",&_);while(_--) {scanf("%d",&n);rep(i,0,n-1) {line[i][0].read();line[i][1].read();}p1.read(), p2.read();int t; scanf("%d",&t), Len = t;init();vector<db> V1 = cal(UP);vector<db> V2 = cal(LW);vector<pair<db,db>> V;rep(i, 0, (int)V1.size()-1) {V.pb({scan[i+1]-scan[i], V1[i] + V2[i]});}db ans = cala(V, Len);printf("%.12Lf\n",ans);}return 0;
}

转载于:https://www.cnblogs.com/RRRR-wys/p/10952057.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/320401.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

P2485-[SDOI2011]计算器【BSGS,exgcd,快速幂】

正题 题目链接:https://www.luogu.com.cn/problem/P2485 题目大意 给出a,b,pa,b,pa,b,p要求一下一种 ab%pa^b\% pab%p的值ax≡b(modp)ax\equiv b(\mod p)ax≡b(modp)的最小非负整数解ax≡b(modp)a^x\equiv b(\mod p)ax≡b(modp)的最小非负整数解 解题思路 一道缝合题 第一个…

幸运数字Ⅱ

牛客网 时间限制&#xff1a;C/C 1秒&#xff0c;其他语言2秒 空间限制&#xff1a;C/C 262144K&#xff0c;其他语言524288K 64bit IO Format: %lld 题目描述 定义一个数字为幸运数字当且仅当它的所有数位都是4或者7。 比如说&#xff0c;47、744、4都是幸运数字而5、17、467都…

【背包】SMRTFUN

SMRTFUN 题目大意&#xff1a; 有n件物品&#xff0c;每件物品有各自的a值和b值&#xff0c;现在让你选一些物品&#xff0c;在a、b都不是负数的情况下&#xff0c;使a、b值之和最大 输入样例 5 -5 7 8 -6 6 -3 2 1 -8 -5输出样例 8样例说明 选择第1&#xff0c;3和4号牛…

Visual Studio 2017 15.8 正式发布,测试速度提高 82%

Visual Studio 2017 15.8 版本已正式发布&#xff1a;发行说明&#xff1a;https://docs.microsoft.com/zh-cn/visualstudio/releasenotes/vs2017-relnotes#15.8下载地址&#xff1a;https://visualstudio.microsoft.com/downloads/安装现可选择在开始安装之前下载所有安装文件…

Codeforces 1176F

Codeforces 1176F 题目 题意&#xff1a;T组物品&#xff0c;按顺序选一个一个选&#xff0c;物品首先要满足组间的相对顺序&#xff0c;每个物品有价值和体积&#xff0c;每组选择的体积不能超过3&#xff0c;组内的选择物品的顺序可以调整&#xff0c;在总的物品的顺序中&…

jzoj5702-[gdoi2018day2]滑稽子图【树形dp,二项式定理】

正题 题目大意 nnn个点的一棵树&#xff0c;定义f(S)f(S)f(S)表示点集SSS的生成子图中的边数量。 求∑S∈Vf(S)k\sum_{S\in V}f(S)^kS∈V∑​f(S)k 解题思路 因为kkk很小&#xff0c;所以可以考虑一下二项式拆解&#xff0c;我们需要快速的计算出(ab)k(ab)^k(ab)k&#xff0c…

【每日一题】4月9日题目精讲 Running Median

文章目录题目&#xff1a;题意&#xff1a;题解一&#xff1a;题解二&#xff1a;题目&#xff1a; –>链接<— 时间限制&#xff1a;C/C 5秒&#xff0c;其他语言10秒 空间限制&#xff1a;C/C 65536K&#xff0c;其他语言131072K 64bit IO Format:%lld 题目描述 For t…

【结论】区间和的和

区间和的和 题目大意&#xff1a; 给出一个数组&#xff0c;求出所有区间和的总和 输入样例&#xff1a; 3 1 2 3输出样例&#xff1a; 20数据范围&#xff1a; 对于30%的数据&#xff1a;1⩽n⩽1001\leqslant n\leqslant 1001⩽n⩽100 对于50%的数据&#xff1a;1⩽n⩽1…

.NET Core 2.1中的HttpClientFactory最佳实践

ASP.NET Core 2.1中出现一个新的HttpClientFactory功能&#xff0c;它有助于解决开发人员在使用HttpClient实例从其应用程序发出外部Web请求时可能遇到的一些常见问题。介绍在.NETCore平台的2.1新增了HttpClientFactory&#xff0c;虽然HttpClient这个类实现了disposable&#…

树学

文章目录题目描述题解1&#xff1a;代码:题解2&#xff1a;代码&#xff1a;传送时间限制&#xff1a;C/C 2秒&#xff0c;其他语言4秒 空间限制&#xff1a;C/C 262144K&#xff0c;其他语言524288K 64bit IO Format:> %lld 题目描述 牛妹有一张连通图&#xff0c;由n个点…

jzoj5701-[gdoi2018day2]谈笑风生【莫比乌斯反演,二分,最短路】

正题 题目大意 nnn个点&#xff0c;每个点有一个wiw_iwi​&#xff0c;mmm条边&#xff0c;对于一条边(x,y)(x,y)(x,y)&#xff0c;边权为∑i1wx∑j1wy[gcd(i,j)1](ij)\sum_{i1}^{w_x}\sum_{j1}^{w_y}[gcd(i,j)1](ij)i1∑wx​​j1∑wy​​[gcd(i,j)1](ij) 选择一个最小的PPP使得…

csp-2019 复赛游记

文章目录Day0Day\ 0Day 0Day1Day\ 1Day 1Day2Day\ 2Day 2总结:csp−J:csp-J:csp−J:csp−s:csp-s:csp−s:遥远的梦想&#xff1a;Day0Day\ 0Day 0 早上&#xff0c;在运动会上乱搞一波&#xff0c;然后在10点左右到了机房&#xff0c;然后发现巨佬几枚&#xff0c;远看似在认证…

Rainbond v3.7.0:实现企业级PaaS的稳定性

Rainbond v3.7.0&#xff1a;实现企业级PaaS的稳定性Rainbond在v3.7.0版本中释出了大量平台稳定性更新&#xff0c;并在应用管理功能、安全性和系统安装三方面进行了部分优化。作为IT基础系统平台&#xff0c;Rainbond从低耦合的架构设计、高可用的部署方式、自恢复与容错的设计…

简单多边形三角化(暴力)

简单多边形三角化(暴力) 说在前面 网上流传着各种神奇的多边形三角剖分算法&#xff0c;但是讲道理&#xff0c;实现难度太高了。。。也没有搜到其他人的实现。这里写个最暴力的做法。。随机数据验证没问题&#xff0c;欢迎 hack 实现 一个简单多边形的耳朵定义为&#xff1a;如…

牛客网【每日一题】4月13号 Accumulation Degree

文章目录题目描述样例分析&#xff1a;题意&#xff1a;题解&#xff1a;代码&#xff1a;本题目传送题目树学是这个题的简易版&#xff0c;也涉及换根问题&#xff0c;可以先看看这个 树学 时间限制&#xff1a;C/C 1秒&#xff0c;其他语言2秒 空间限制&#xff1a;C/C 32768…

【二分】Distinct

Distinct 题目大意&#xff1a; 有n个军队&#xff08;有自己在x轴上的坐标&#xff09;&#xff0c;每个军队有一定的人&#xff0c;要一个坐标只有一个人&#xff0c;移动路程最大的士兵最少移动多长 原题&#xff1a; 题目描述 Daniel 正在玩一个战棋游戏。 现在 Danie…

P2839-[国家集训队]middle【主席树,二分】

正题 题目链接:https://www.luogu.com.cn/problem/P2839 题目大意 nnn个数字&#xff0c;mmm次询问给出(a,b,c,d)(a,b,c,d)(a,b,c,d)表示左端点在[a,b][a,b][a,b]中&#xff0c;右端点在[c,d][c,d][c,d]的子区间中中位数最大的值。 解题思路 显然我们需要二分一下答案midmidm…

微软把UWP定位成业务线应用程序开发平台

微软把UWP定位成传统业务线&#xff08;LOB&#xff09;应用程序开发平台&#xff0c;以使用Windows Template Studio实现快速应用程序开发为重点。但是&#xff0c;为了把LOB开发人员吸引到UWP平台&#xff0c;他们在做的事情不止这些。最初发布时&#xff0c;通用Windows平台…

牛客网【每日一题】 合集

文章目录2020年3月25日 NC50439 tokitsukaze and Soldier 牛客练习赛50-C2020年3月26日 NC13230 合并回文子串 美团2017年CodeM大赛-初赛A轮2020年3月27日 NC15553 数学考试 2018年长沙理工大学程序设计竞赛2020年3月30日 NC50528 滑动窗口 《信息学奥赛一本通》Part5.52020年3…

NBA总冠军

NBA总冠军NBA总冠军NBA总冠军 题目描述 又要考试了&#xff0c;LJW决定放松一下&#xff0c;就打开电视&#xff0c;看见篮球赛&#xff0c;他立即想到了每年的NBA总冠军队伍。由于复习紧张&#xff0c;他只记起了一部分&#xff0c;记忆的内容是正确的&#xff0c;可能不是按…