QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#745193 | #8082. Minimum Euclidean Distance | yhddd | AC ✓ | 195ms | 3996kb | C++14 | 1.8kb | 2024-11-14 08:10:40 | 2024-11-14 08:10:42 |
Judging History
answer
#include<bits/stdc++.h>
#define int long long
#define mod 998244353ll
#define pii pair<db,db>
#define fi first
#define se second
#define mems(x,y) memset(x,y,sizeof(x))
#define pb push_back
#define db double
using namespace std;
const int maxn=200010;
const int inf=2e18;
const db eps=1e-8;
inline int read(){
int x=0,f=1;
char ch=getchar();
while(ch<'0'||ch>'9'){if(ch=='-')f=-1;ch=getchar();}
while(ch>='0'&&ch<='9'){x=(x<<3)+(x<<1)+(ch-48);ch=getchar();}
return x*f;
}
bool Mbe;
int n,q;
pii a[maxn];
db cross(pii u,pii v){return u.fi*v.se-u.se*v.fi;}
db mul(pii u,pii v){return u.fi*v.fi+u.se*v.se;}
pii operator-(pii u,pii v){return {u.fi-v.fi,u.se-v.se};}
db dis(pii u,pii v){return sqrtl((u.fi-v.fi)*(u.fi-v.fi)+(u.se-v.se)*(u.se-v.se));}
db area(pii u,pii v,pii w){return abs(u.fi*v.se+v.fi*w.se+w.fi*u.se-u.fi*w.se-v.fi*u.se-w.fi*v.se)/2;}
db dis(pii u,pii v,pii w){
db d=abs(area(u,v,w))*2/dis(v,w);
// cout<<d<<" "<<dis(u,v)<<" "<<dis(u,w)<<"\n";
if(mul(u-w,v-w)<-eps||mul(u-v,w-v)<-eps)return min(dis(u,v),dis(u,w));
return d;
}
void work(){
n=read();q=read();
for(int i=1;i<=n;i++)a[i]={read(),read()};a[n+1]=a[1];
while(q--){
pii b={read(),read()},c={read(),read()};
pii o={(b.fi+c.fi)/2,(b.se+c.se)/2};
db r=dis(o,b);
db ans=inf;
for(int i=1;i<=n;i++){
ans=min(ans,dis(o,a[i],a[i+1]));
// cout<<i<<" "<<ans<<"\n";
}
bool fl=1;
for(int i=1;i<=n;i++)if(cross(a[i+1]-a[i],o-a[i])<-eps)fl=0;
if(fl)ans=0;
// cout<<r<<" "<<ans<<" "<<fl<<"\n";
printf("%.10lf\n",r*r/2+ans*ans);
}
}
// \
444
bool Med;
int T;
signed main(){
// freopen(".in","r",stdin);
// freopen(".out","w",stdout);
// ios::sync_with_stdio(0);
// cin.tie(0);cout.tie(0);
// cerr<<(&Mbe-&Med)/1048576.0<<" MB\n";
T=1;
while(T--)work();
}
详细
Test #1:
score: 100
Accepted
time: 0ms
memory: 3920kb
input:
4 3 0 0 1 0 1 1 0 1 0 0 1 1 1 1 2 2 1 1 2 3
output:
0.2500000000 0.7500000000 1.8750000000
result:
ok Your answer is acceptable!^ ^
Test #2:
score: 0
Accepted
time: 0ms
memory: 3812kb
input:
48 10 -30 0 -29 -4 -28 -7 -27 -9 -25 -12 -22 -16 -21 -17 -17 -20 -14 -22 -12 -23 -9 -24 -5 -25 -4 -25 0 -24 3 -23 5 -22 8 -20 12 -17 13 -16 16 -12 18 -9 19 -7 20 -4 21 0 21 1 20 5 19 8 18 10 16 13 13 17 12 18 8 21 5 23 3 24 0 25 -4 26 -5 26 -9 25 -12 24 -14 23 -17 21 -21 18 -22 17 -25 13 -27 10 -28 ...
output:
589.5000000000 51.4705882353 1051.2500000000 66.6250000000 174.1250000000 562.6750000000 272.3942307692 287.3850000000 689.6250000000 436.2500000000
result:
ok Your answer is acceptable!^ ^
Test #3:
score: 0
Accepted
time: 195ms
memory: 3944kb
input:
5000 5000 -50000000 0 -49999885 -49450 -49999770 -85675 -49999604 -122394 -49999391 -157604 -49999130 -192731 -49998803 -229143 -49998399 -267196 -49997956 -303872 -49997469 -339362 -49996891 -377221 -49996257 -414903 -49995577 -451819 -49994843 -488600 -49994059 -524941 -49993173 -563137 -49992252 ...
output:
2214785369560633.0000000000 1632645104370924.5000000000 3954739966640761.0000000000 5405105667896786.0000000000 817274719687553.1250000000 902260846427661.1250000000 3194363161448624.0000000000 1619744446324385.0000000000 363457485421825.1875000000 4776425533214309.0000000000 8267595460255074.000000...
result:
ok Your answer is acceptable!^ ^
Test #4:
score: 0
Accepted
time: 85ms
memory: 3892kb
input:
2224 5000 -500000 0 -499999 -30 -499998 -59 -499997 -87 -499996 -114 -499995 -140 -499994 -165 -499993 -189 -499992 -212 -499991 -234 -499990 -255 -499989 -275 -499988 -294 -499987 -312 -499986 -329 -499985 -345 -499984 -360 -499982 -389 -499981 -403 -499979 -430 -499978 -443 -499976 -468 -499975 -4...
output:
931340796015.3750000000 410570465847.7500000000 225774975043.7500000000 686588110927.3748779297 803635163394.8750000000 440321806244.7500000000 781364862674.5000000000 303496624306.7500000000 146653887864.7500000000 1361017661096.7497558594 409649028457.5000000000 417747460932.7500000000 46509181005...
result:
ok Your answer is acceptable!^ ^
Test #5:
score: 0
Accepted
time: 181ms
memory: 3796kb
input:
4672 5000 -300 0 -299 -43 -298 -85 -297 -126 -296 -166 -295 -205 -294 -243 -293 -280 -292 -316 -291 -351 -290 -385 -289 -418 -288 -450 -287 -481 -286 -511 -285 -540 -284 -568 -283 -595 -282 -621 -281 -646 -280 -670 -279 -693 -278 -715 -276 -758 -275 -779 -273 -820 -272 -840 -270 -879 -269 -898 -267 ...
output:
356616.5000000000 121018.5000000000 0.2500000000 189.6250000000 103099.6250000000 83253.1250000000 131701.2500000000 58352.5000000000 355863.1250000000 197638.8597240473 605772.4121621621 2062.4458977408 113763.2500000000 134694.5000000000 74679.6520547945 114481.2500000000 60577.2500000000 7456.250...
result:
ok Your answer is acceptable!^ ^
Test #6:
score: 0
Accepted
time: 25ms
memory: 3884kb
input:
576 5000 -300 0 -299 -15 -298 -29 -297 -42 -296 -54 -295 -65 -294 -75 -293 -84 -292 -92 -290 -107 -289 -114 -287 -127 -286 -133 -284 -144 -283 -149 -280 -163 -278 -172 -275 -185 -274 -189 -270 -204 -267 -215 -265 -222 -262 -232 -258 -245 -257 -248 -252 -262 -248 -273 -245 -281 -240 -294 -238 -299 -2...
output:
189295.2500000000 377943.2944162437 299473.0000000000 243821.9171974522 559270.9922279794 100367.5923396674 472743.1249999999 374450.6249999999 77260.6250000000 106891.2307692308 193578.1250000000 98895.0654145078 124020.0000000000 296138.8749999999 1209.1250000000 480040.6250000000 133543.970689655...
result:
ok Your answer is acceptable!^ ^
Test #7:
score: 0
Accepted
time: 16ms
memory: 3872kb
input:
336 5000 -300 0 -299 -11 -298 -21 -297 -30 -296 -38 -295 -45 -294 -51 -292 -62 -291 -67 -289 -76 -288 -80 -285 -91 -283 -98 -280 -108 -279 -111 -275 -122 -272 -130 -270 -135 -267 -142 -263 -151 -258 -162 -257 -164 -251 -175 -246 -184 -242 -191 -239 -196 -234 -204 -227 -215 -225 -218 -218 -228 -213 -...
output:
478.1250000000 408.1250000000 1341.2500000000 861.2500000000 4210.0000000000 1709.1250000000 846.2500000000 1389.1250000000 722.5000000000 753.1250000000 574.2500000000 1167.1250000000 439.6250000000 5650.2500000000 619.6250000000 2664.5000000000 2138.6250000000 2138.6250000000 1226.2500000000 1226....
result:
ok Your answer is acceptable!^ ^
Test #8:
score: 0
Accepted
time: 16ms
memory: 3872kb
input:
336 5000 -300 0 -299 -11 -298 -21 -297 -30 -296 -38 -295 -45 -294 -51 -292 -62 -291 -67 -289 -76 -288 -80 -285 -91 -283 -98 -280 -108 -279 -111 -275 -122 -272 -130 -270 -135 -267 -142 -263 -151 -258 -162 -257 -164 -251 -175 -246 -184 -242 -191 -239 -196 -234 -204 -227 -215 -225 -218 -218 -228 -213 -...
output:
95.1250000000 8382.6250000000 77361.1250000000 142408.1250000000 98056.2500000000 110581.2500000000 20413.0000000000 1253.1250000000 64468.6250000000 8915.6250000000 93179.1250000000 26286.2500000000 35118.2500000000 129681.2500000000 59545.6250000000 49997.9103773585 1685.1250000000 58020.625000000...
result:
ok Your answer is acceptable!^ ^
Test #9:
score: 0
Accepted
time: 195ms
memory: 3996kb
input:
5000 5000 -50000000 0 -49999912 -33572 -49999824 -59400 -49999710 -83347 -49999578 -105149 -49999382 -130924 -49999166 -154591 -49998916 -178069 -49998599 -203894 -49998262 -228398 -49997905 -251647 -49997466 -277451 -49997003 -302413 -49996511 -326907 -49995964 -352128 -49995393 -376671 -49994795 -...
output:
481990667522174144.0000000000 900047257776892032.0000000000 84250235108292080.0000000000 357963472278544256.0000000000 758024710210129280.0000000000 651805790712522752.0000000000 422072215223185856.0000000000 571948904059660544.0000000000 685946954834849920.0000000000 781017527404628096.0000000000 3...
result:
ok Your answer is acceptable!^ ^
Test #10:
score: 0
Accepted
time: 195ms
memory: 3940kb
input:
5000 5000 -50000000 0 -49999762 -138397 -49999461 -244153 -49999007 -349713 -49998392 -456086 -49997577 -566637 -49996632 -673023 -49995462 -784273 -49994137 -894156 -49992625 -1005080 -49990945 -1115094 -49989066 -1226720 -49987021 -1337531 -49984788 -1449227 -49982415 -1559155 -49979887 -1668061 -...
output:
259053256470500416.0000000000 472297859897907072.0000000000 271976522374482752.0000000000 930648882061706112.0000000000 110596174224097024.0000000000 385963660067947136.0000000000 441658538323329024.0000000000 259108189662189408.0000000000 379723545376251136.0000000000 43293951022380792.0000000000 2...
result:
ok Your answer is acceptable!^ ^
Extra Test:
score: 0
Extra Test Passed