QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#883565 | #6302. Map | AMATSUKAZE# | AC ✓ | 2ms | 4224kb | C++20 | 2.6kb | 2025-02-05 17:01:56 | 2025-02-05 17:01:58 |
Judging History
answer
#include<bits/stdc++.h>
#define rep(i,s,n) for (int i = (int)(s); i < (int)(n); i++)
#define all(v) begin(v),end(v)
using namespace std;
using ll = long long;
bool chmin(auto &a, auto b){ return a > b ? a = b, 1 : 0; }
bool chmax(auto &a, auto b){ return a < b ? a = b, 1 : 0; }
double dist(double x1, double y1, double x2, double y2) {
return sqrt((x1 - x2) * (x1 - x2) + (y1 - y2) * (y1 - y2));
}
typedef pair<double,double> pd;
void solve() {
vector<double> x1(4), y1(4);
vector<double> x2(4), y2(4);
rep(i,0,4) cin >> x1[i] >> y1[i];
rep(i,0,4) cin >> x2[i] >> y2[i];
double sx, sy, tx, ty;
cin >> sx >> sy;
cin >> tx >> ty;
double getax = x1[0];
double getay = y1[0];
sx -= getax;
sy -= getay;
tx -= getax;
ty -= getay;
rep(i,0,4) {
x1[i] -= getax;
y1[i] -= getay;
x2[i] -= getax;
y2[i] -= getay;
}
double k; cin >> k;
int n; cin >> n;
pd va1, va2, vb1, vb2;
va1 = pair(x1[1] - x1[0], y1[1] - y1[0]);
va2 = pair(x1[3] - x1[0], y1[3] - y1[0]);
vb1 = pair(x2[1] - x2[0], y2[1] - y2[0]);
vb2 = pair(x2[3] - x2[0], y2[3] - y2[0]);
vector ma(2, vector<double>(2));
ma[0][0] = va2.second;
ma[0][1] = -va2.first;
ma[1][0] = -va1.second;
ma[1][1] = va1.first;
double det = va1.first * va2.second - va1.second * va2.first;
rep(i,0,2) rep(j,0,2) {
ma[i][j] /= det;
}
vector<pd> sgo(n + 1), tgo(n + 1);
sgo[0] = pair(sx, sy);
tgo[0] = pair(tx, ty);
auto f = [&](pd x) -> pd {
vector<double> factor(2);
factor[0] += ma[0][0] * x.first;
factor[0] += ma[0][1] * x.second;
factor[1] += ma[1][0] * x.first;
factor[1] += ma[1][1] * x.second;
pd ans;
ans.first = factor[0] * vb1.first + factor[1] * vb2.first + x2[0];
ans.second = factor[0] * vb1.second + factor[1] * vb2.second + y2[0];
return ans;
};
for (int i=1; i<=n; i++) {
sgo[i] = f(sgo[i-1]);
tgo[i] = f(tgo[i-1]);
//cout << sgo[i].first << ' ' << sgo[i].second << endl;
}
double ret = 9e18;
rep(i,0,n+1) {
rep(j,0,n+1-i) {
double tmp = k * (i + j);
tmp += dist(sgo[i].first, sgo[i].second, tgo[j].first, tgo[j].second);
chmin(ret, tmp);
}
}
cout << ret << '\n';
}
int main(){
cin.tie(0)->sync_with_stdio(0);
cout << fixed << setprecision(15);
int t;
cin >> t;
while(t--) {
solve();
}
}
詳細信息
Test #1:
score: 100
Accepted
time: 1ms
memory: 4096kb
input:
2 0 0 0 2 4 2 4 0 0 0 0 1 2 1 2 0 2 1 4 2 1 1 0 0 0 3 6 3 6 0 0 1 1 0 3 2 2 3 0 0 4 2 0 3
output:
1.000000000000000 1.227262335243029
result:
ok 2 numbers
Test #2:
score: 0
Accepted
time: 0ms
memory: 4224kb
input:
100 -133 -128 -109 -134 -85 -38 -109 -32 -95 -37 -100 -35 -108 -55 -103 -57 -119 -130 -112 -44 2 73 5 -100 5 -8 1 -8 1 -100 1 -60 1 -14 3 -14 3 -60 3 -84 1 -20 2 53 -58 -78 -66 -78 -66 -34 -58 -34 -58 -34 -66 -34 -66 -78 -58 -78 -63 -50 -63 -37 4 54 52 -148 116 -148 116 -52 52 -52 53 -103 53 -71 101...
output:
9.500657499741557 12.229731078922157 13.000000000000000 17.488532900375080 13.341664064126334 7.615773105863909 23.409399821439251 7.280109889280518 21.280037734083884 59.776022092579126 4.123105625617661 79.649231006959511 65.069193939989759 14.142135623730951 41.824615503479755 16.056245184896987 ...
result:
ok 100 numbers
Test #3:
score: 0
Accepted
time: 1ms
memory: 4224kb
input:
100 -173 -113 -120 -113 -120 -115 -173 -115 -173 -115 -120 -115 -120 -113 -173 -113 -162 -114 -152 -114 99 57 6 23 -75 4 -56 -77 25 -58 0 -58 -51 -69 -62 -18 -11 -7 -22 -56 -42 -25 19 27 -98 -115 -150 -147 -158 -134 -106 -102 -150 -147 -98 -115 -106 -102 -158 -134 -103 -111 -136 -134 25 50 136 -92 1...
output:
10.000000000000000 25.483637975584358 40.224370722237531 18.384776310850235 9.219544457292887 18.027756377319946 43.114063026280348 52.887044352349008 45.541190146942803 55.000999975001250 37.000000000000000 12.041594578792296 24.331050121192877 18.110770276274835 7.563262753279502 2.236067977499790...
result:
ok 100 numbers
Test #4:
score: 0
Accepted
time: 0ms
memory: 4224kb
input:
100 -12 -206 72 -188 135 -482 51 -500 19 -301 23 -301 23 -315 19 -315 88 -368 28 -248 14 87 -221 -566 -467 -566 -467 -565 -221 -565 -221 -566 -467 -566 -467 -565 -221 -565 -297 -566 -289 -566 274 18 -264 759 -339 609 -129 504 -54 654 -208 580 -208 655 -103 655 -103 580 -196 664 -211 596 8 64 -111 -3...
output:
34.246950475544239 8.000000000000000 45.926952286842941 135.118466539551889 131.973482184869255 40.349665953953490 15.321347728712514 77.772275035020499 66.738813035899369 8.000266654815842 116.806446031673104 12.588290015615980 170.785630266285693 131.962750429094399 8.738089975160307 17.4642491965...
result:
ok 100 numbers
Test #5:
score: 0
Accepted
time: 1ms
memory: 4096kb
input:
100 -235 -704 133 -704 133 -720 -235 -720 -224 -712 -40 -712 -40 -704 -224 -704 15 -711 76 -718 4 74 -467 574 -475 596 -123 724 -115 702 -274 662 -270 652 -430 588 -434 598 -458 588 -241 657 15 31 380 -3 532 -343 787 -229 635 111 503 -71 639 -163 708 -61 572 31 533 -189 613 -137 3 58 -460 -7 -488 -7...
output:
31.350081433008754 51.967632320937994 21.468697928146774 38.837932076467766 84.248187428308029 77.929455278476055 47.000000000000000 74.115493725912501 86.467104880421701 35.114099732158877 3.605551275463989 97.416631023660429 24.606056965764537 56.773359432723908 6.998534619414935 13.45362404707371...
result:
ok 100 numbers
Test #6:
score: 0
Accepted
time: 1ms
memory: 4224kb
input:
100 -1201 2822 -1197 2814 -3437 1694 -3441 1702 -3119 1860 -3117 1856 -1997 2416 -1999 2420 -1419 2709 -2491 2174 48 76 -2515 285 -2547 306 -1308 2194 -1276 2173 -2255 683 -2260 686 -2083 981 -2078 978 -1572 1753 -1392 2015 121 28 -1216 1209 -1498 -1141 -1598 -1129 -1316 1221 -1494 -823 -1494 -447 -...
output:
264.055863532879073 290.425700450936404 258.282400313066432 743.737184763542700 341.052781838823307 400.566683662432581 172.040799340956909 27.770894609837850 294.825880152081140 508.065910688872975 501.781825099315427 666.805068966935778 180.069431053691062 193.610433603150625 1507.002986062071386 ...
result:
ok 100 numbers
Test #7:
score: 0
Accepted
time: 1ms
memory: 4096kb
input:
100 1411 -2755 603 -3563 623 -3583 1431 -2775 716 -3477 1120 -3073 1110 -3063 706 -3467 1210 -2959 1339 -2830 2319 39 4528 -3417 4286 -4055 1908 -3153 2150 -2515 2094 -2892 2094 -3090 2832 -3090 2832 -2892 2257 -2993 4389 -3736 17 22 -180 -1673 -2172 -3665 -2164 -3673 -172 -1681 -284 -1792 -2027 -35...
output:
182.433549546129257 96.880923053928456 530.330085889910606 44.011362169330773 64.313365366181941 7.392893666126138 34.567810207462394 148.850160742992557 350.338135916148474 329.225162779821176 68.864765108872987 32.824383174612812 244.695729427384975 685.968837711980882 141.362747995939088 1601.789...
result:
ok 100 numbers
Test #8:
score: 0
Accepted
time: 2ms
memory: 4224kb
input:
100 11928 -18111 8928 -17411 11056 -8291 14056 -8991 11043 -10811 10793 -10111 12921 -9351 13171 -10051 10491 -14092 11923 -12413 10 92 11869 -4371 3539 5429 1299 3525 9629 -6275 8302 -3064 3647 2571 4935 3635 9590 -2000 2384 2680 3466 2644 181 91 4001 -10187 4001 -10897 9 -10897 9 -10187 838 -10629...
output:
87.479657002630546 977.209322820567422 94.486325059360638 307.006514588860171 1245.629559700635809 532.000000000000000 369.048777263927548 19.554024317232663 1509.000000000000000 275.094267211330020 4242.193351514708411 465.656251408810078 3478.304242060182787 1754.356007200362910 1804.4669275859330...
result:
ok 100 numbers
Test #9:
score: 0
Accepted
time: 2ms
memory: 4096kb
input:
100 10303 -4099 19487 -8131 19703 -7639 10519 -3607 18394 -7495 18842 -7271 18854 -7295 18406 -7519 15852 -6248 15950 -6389 38 10 13132 -3411 17416 3393 15634 4515 11350 -2289 13143 -873 15411 3411 16533 2817 14265 -1467 16515 2577 16017 1561 198 94 -5480 10872 -6297 11294 -11361 1490 -10544 1068 -1...
output:
84.574886489292524 999.689277678129429 6231.529667746114683 550.947886095034846 182.544124658606279 5374.296791209059847 825.725781096656533 1653.207429169171519 2777.109648537486009 166.653023806102027 1747.004579272761930 651.111357603290458 242.210006732268425 34.266895846221601 286.7908645685911...
result:
ok 100 numbers
Test #10:
score: 0
Accepted
time: 1ms
memory: 4096kb
input:
100 0 -30 84 12 126 -72 42 -114 0 -30 84 12 126 -72 42 -114 91 -41 100 -55 96 93 168 110 148 150 48 100 68 60 48 100 68 60 168 110 148 150 61 96 102 90 8 2 -123 129 -60 174 -15 111 -78 66 -15 111 -78 66 -123 129 -60 174 -44 115 -104 132 27 3 27 42 15 54 -75 -36 -63 -48 -63 -48 -75 -36 15 54 27 42 -4...
output:
16.643316977093239 41.436698710201320 39.206555615733699 11.180339887498949 49.729267036625423 26.925824035672520 50.931326312987373 10.294055820165386 117.885537705012823 8.602325267042627 48.466483264210538 21.095023109728988 24.038404810405286 16.000000000000000 48.548944375753422 26.061756859551...
result:
ok 100 numbers
Test #11:
score: 0
Accepted
time: 0ms
memory: 4096kb
input:
100 9725 6731 9725 11971 14965 11971 14965 6731 9725 6731 9725 11971 14965 11971 14965 6731 10293 11185 10445 9833 488 10 3833 -4831 6913 -4271 8443 -12686 5363 -13246 6913 -4271 3833 -4831 5363 -13246 8443 -12686 5209 -4960 7133 -6409 1 88 -5891 -6066 -8365 -6066 -8365 -8540 -5891 -8540 -8365 -6066...
output:
1360.517548582156223 2119.674780139698214 1638.601494195408577 144.699689011414250 1706.299211744528748 2671.668018298680636 1442.324859385013951 2909.931270666027103 5311.386353862802935 7894.844203655952697 2950.721437208195766 1405.197279587166804 8052.785977535972961 436.084854128184531 1910.190...
result:
ok 100 numbers
Test #12:
score: 0
Accepted
time: 1ms
memory: 4096kb
input:
100 1432065 -1359744 1432065 -1359796 610089 -1359796 610089 -1359744 610089 -1359744 610089 -1359796 1432065 -1359796 1432065 -1359744 1413145 -1359747 670086 -1359765 306 12 -630899 -570942 344981 -570942 344981 -567164 -630899 -567164 -630899 -567164 344981 -567164 344981 -570942 -630899 -570942 ...
output:
41383.003943812647776 344430.708764477050863 597464.947160122217610 57512.000021251275029 180112.504983949329471 254594.189465463656234 13301.834367630912311 246235.741341503860895 17086.953736696308624 168329.001188149384689 580568.278437601169571 120047.475965045290650 24722.575937794183119 252882...
result:
ok 100 numbers
Test #13:
score: 0
Accepted
time: 1ms
memory: 3968kb
input:
100 -240497 1168822 -365542 931192 504344 473443 629389 711073 226221 683190 167481 688085 185400 903113 244140 898218 -192129 1110656 34450 941656 2 25 1729381 25950 1512625 519672 1528369 526584 1745125 32862 1536820 492965 1580974 388601 1584302 390009 1540148 494373 1660204 207517 1601591 344571...
output:
33.523773639177868 126504.999518608878134 57518.293697332905140 318943.663702541671228 169769.250005668785889 1497.133893067358713 23459.324991965055233 853.347816095368785 28.351411845901751 7526.106524036470546 36705.816569039845490 575.015321675166660 4025.084882224957255 31458.023666467033763 31...
result:
ok 100 numbers
Test #14:
score: 0
Accepted
time: 2ms
memory: 4224kb
input:
100 -889209 606569 -191736 1436894 638589 739421 -58884 -90904 -58884 -90904 638589 739421 -191736 1436894 -889209 606569 -486300 891465 -464854 988546 79 18 -1226546 957048 -712144 1926170 -590407 1861553 -1104809 892431 -712144 1926170 -1226546 957048 -1104809 892431 -590407 1861553 -807239 146415...
output:
99421.584562910677050 404181.388824374240357 311311.528917577990796 271785.624537060444709 319158.191839094099123 77725.025543495052261 103690.241569289937615 33781.004277552201529 16708.608350188831537 262422.768227149092127 176381.843093329749536 159818.483940375299426 451836.634220813575666 29166...
result:
ok 100 numbers