QOJ.ac

QOJ

IDProblemSubmitterResultTimeMemoryLanguageFile sizeSubmit timeJudge time
#883565#6302. MapAMATSUKAZE#AC ✓2ms4224kbC++202.6kb2025-02-05 17:01:562025-02-05 17:01:58

Judging History

This is the latest submission verdict.

  • [2025-02-05 17:01:58]
  • Judged
  • Verdict: AC
  • Time: 2ms
  • Memory: 4224kb
  • [2025-02-05 17:01:56]
  • Submitted

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();
    }
}

Details

Tip: Click on the bar to expand more detailed information

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