QOJ.ac

QOJ

IDProblemSubmitterResultTimeMemoryLanguageFile sizeSubmit timeJudge time
#120169#6302. Maphos_lyricAC ✓2ms3788kbC++144.3kb2023-07-06 14:24:162023-07-06 14:25:14

Judging History

你现在查看的是最新测评结果

  • [2023-08-10 23:21:45]
  • System Update: QOJ starts to keep a history of the judgings of all the submissions.
  • [2023-07-06 14:25:14]
  • 评测
  • 测评结果:AC
  • 用时:2ms
  • 内存:3788kb
  • [2023-07-06 14:24:16]
  • 提交

answer

#include <cassert>
#include <cmath>
#include <cstdint>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <algorithm>
#include <bitset>
#include <complex>
#include <deque>
#include <functional>
#include <iostream>
#include <map>
#include <numeric>
#include <queue>
#include <set>
#include <sstream>
#include <string>
#include <unordered_map>
#include <unordered_set>
#include <utility>
#include <vector>

using namespace std;

using Int = long long;

template <class T1, class T2> ostream &operator<<(ostream &os, const pair<T1, T2> &a) { return os << "(" << a.first << ", " << a.second << ")"; };
template <class T> ostream &operator<<(ostream &os, const vector<T> &as) { const int sz = as.size(); os << "["; for (int i = 0; i < sz; ++i) { if (i >= 256) { os << ", ..."; break; } if (i > 0) { os << ", "; } os << as[i]; } return os << "]"; }
template <class T> void pv(T a, T b) { for (T i = a; i != b; ++i) cerr << *i << " "; cerr << endl; }
template <class T> bool chmin(T &t, const T &f) { if (t > f) { t = f; return true; } return false; }
template <class T> bool chmax(T &t, const T &f) { if (t < f) { t = f; return true; } return false; }


using Double = long double;

const Double EPS = 1e-10L;
const Double INF = 1e+10L;
const Double PI = acos(-1.0L);
inline int sig(Double r) { return (r < -EPS) ? -1 : (r > +EPS) ? +1 : 0; }

struct Pt {
  Double x, y;
  Pt() {}
  Pt(Double x_, Double y_) : x(x_), y(y_) {}
  Pt operator+(const Pt &a) const { return Pt(x + a.x, y + a.y); }
  Pt operator-(const Pt &a) const { return Pt(x - a.x, y - a.y); }
  Pt operator*(const Pt &a) const { return Pt(x * a.x - y * a.y, x * a.y + y * a.x); }
  Pt operator/(const Pt &a) const { const Double d2 = a.abs2(); return Pt((x * a.x + y * a.y) / d2, (y * a.x - x * a.y) / d2); }
  Pt operator+() const { return Pt(+x, +y); }
  Pt operator-() const { return Pt(-x, -y); }
  Pt operator*(const Double &k) const { return Pt(x * k, y * k); }
  Pt operator/(const Double &k) const { return Pt(x / k, y / k); }
  friend Pt operator*(const Double &k, const Pt &a) { return Pt(k * a.x, k * a.y); }
  Pt &operator+=(const Pt &a) { x += a.x; y += a.y; return *this; }
  Pt &operator-=(const Pt &a) { x -= a.x; y -= a.y; return *this; }
  Pt &operator*=(const Pt &a) { return *this = *this * a; }
  Pt &operator/=(const Pt &a) { return *this = *this / a; }
  Pt &operator*=(const Double &k) { x *= k; y *= k; return *this; }
  Pt &operator/=(const Double &k) { x /= k; y /= k; return *this; }
  Double abs() const { return sqrt(x * x + y * y); }
  Double abs2() const { return x * x + y * y; }
  Double arg() const { return atan2(y, x); }
  Double dot(const Pt &a) const { return x * a.x + y * a.y; }
  Double det(const Pt &a) const { return x * a.y - y * a.x; }
  friend ostream &operator<<(ostream &os, const Pt &a) { os << "(" << a.x << ", " << a.y << ")"; return os; }
};

inline Double tri(const Pt &a, const Pt &b, const Pt &c) { return (b - a).det(c - a); }


int main() {
  double K;
  int N;
  Pt P[10];
  
  for (int numCases; ~scanf("%d", &numCases); ) { for (int caseId = 1; caseId <= numCases; ++caseId) {
    for (int i = 0; i < 10; ++i) {
      int x, y;
      scanf("%d%d", &x, &y);
      P[i] = Pt(x, y);
    }
    {
      int k;
      scanf("%d", &k);
      K = k;
    }
    scanf("%d", &N);
    
    const Pt dir1 = P[1] - P[0];
    const Pt dir3 = P[3] - P[0];
    const Pt dir5 = P[5] - P[4];
    const Pt dir7 = P[7] - P[4];
    
    vector<Pt> pss[10];
    for (int i = 8; i < 10; ++i) {
      pss[i].resize(N + 1);
      pss[i][0] = P[i];
      for (int j = 0; j < N; ++j) {
        const Pt p = pss[i][j];
        
        const Double t1 = (p - P[0]).dot(dir1) / dir1.abs2();
        const Double t3 = (p - P[0]).dot(dir3) / dir3.abs2();
        const Pt q = P[4] + t1 * dir5 + t3 * dir7;
        
        pss[i][j + 1] = q;
      }
    }
    
    Double ans = INF;
    for (int j8 = 0; j8 <= N; ++j8) for (int j9 = 0; j8 + j9 <= N; ++j9) {
      Double cost = 0.0;
      cost += K * (j8 + j9);
      cost += (pss[8][j8] - pss[9][j9]).abs();
// cerr<<j8<<" "<<j9<<": "<<pss[8][j8]<<" "<<pss[9][j9]<<" "<<cost<<endl;
      chmin(ans, cost);
    }
    printf("%.12Lf\n", ans);
  }
#ifndef LOCAL
  break;
#endif
  }
  return 0;
}

Details

Tip: Click on the bar to expand more detailed information

Test #1:

score: 100
Accepted
time: 1ms
memory: 3724kb

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.000000000000
1.227262335243

result:

ok 2 numbers

Test #2:

score: 0
Accepted
time: 2ms
memory: 3652kb

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.500657499742
12.229731078922
13.000000000000
17.488532900375
13.341664064126
7.615773105864
23.409399821439
7.280109889281
21.280037734084
59.776022092579
4.123105625618
79.649231006960
65.069193939990
14.142135623731
41.824615503480
16.056245184897
15.672617529929
21.562202374203
66.272166103124
...

result:

ok 100 numbers

Test #3:

score: 0
Accepted
time: 2ms
memory: 3664kb

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.000000000000
25.483637975584
40.224370722238
18.384776310850
9.219544457293
18.027756377320
43.114063026280
52.887044352349
45.541190146943
55.000999975001
37.000000000000
12.041594578792
24.331050121193
18.110770276275
7.563262753280
2.236067977500
8.236067977500
14.864765108873
6.324555320337
6...

result:

ok 100 numbers

Test #4:

score: 0
Accepted
time: 2ms
memory: 3788kb

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.246950475544
8.000000000000
45.926952286843
135.118466539552
131.973482184869
40.349665953953
15.321347728713
77.772275035021
66.738813035899
8.000266654816
116.806446031673
12.588290015616
170.785630266286
131.962750429094
8.738089975160
17.464249196573
15.499659842874
26.069836145638
258.073632...

result:

ok 100 numbers

Test #5:

score: 0
Accepted
time: 2ms
memory: 3652kb

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.350081433009
51.967632320938
21.468697928147
38.837932076468
84.248187428308
77.929455278476
47.000000000000
74.115493725912
86.467104880422
35.114099732159
3.605551275464
97.416631023660
24.606056965765
56.773359432724
6.998534619415
13.453624047074
150.786165723470
65.855903304108
26.1725046566...

result:

ok 100 numbers

Test #6:

score: 0
Accepted
time: 2ms
memory: 3648kb

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.055863532879
290.425700450936
258.282400313066
743.737184763543
341.052781838823
400.566683662433
172.040799340957
27.770894609838
294.825880152081
508.065910688873
501.781825099315
666.805068966936
180.069431053691
193.610433603151
1507.002986062071
25.019992006394
81.748007498489
346.028984289...

result:

ok 100 numbers

Test #7:

score: 0
Accepted
time: 2ms
memory: 3696kb

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.433549546129
96.880923053929
530.330085889911
44.011362169331
64.313365366182
7.392893666126
34.567810207462
148.850160742993
350.338135916149
329.225162779821
68.864765108873
32.824383174613
244.695729427385
685.968837711981
141.362747995939
1601.789826722722
6.885591146174
70.671460705627
5.17...

result:

ok 100 numbers

Test #8:

score: 0
Accepted
time: 2ms
memory: 3656kb

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.479657002631
977.209322820567
94.486325059361
307.006514588860
1245.629559700636
532.000000000000
369.048777263928
19.554024317233
1509.000000000000
275.094267211329
4242.193351514708
465.656251408810
3478.304242060183
1754.356007200363
1804.466927585933
21.353142660627
415.415534624568
1526.4344...

result:

ok 100 numbers

Test #9:

score: 0
Accepted
time: 2ms
memory: 3788kb

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.574886489292
999.689277678130
6231.529667746114
550.947886095035
182.544124658606
5374.296791209060
825.725781096656
1653.207429169172
2777.109648537486
166.653023806101
1747.004579272762
651.111357603290
242.210006732268
34.266895846222
286.790864568591
2405.246628920583
2133.342213523184
1310.9...

result:

ok 100 numbers

Test #10:

score: 0
Accepted
time: 0ms
memory: 3652kb

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.643316977093
41.436698710201
39.206555615734
11.180339887499
49.729267036625
26.925824035673
50.931326312987
10.294055820165
117.885537705013
8.602325267043
48.466483264211
21.095023109729
24.038404810405
16.000000000000
48.548944375753
26.061756859551
39.539832078341
10.770329614269
20.973213749...

result:

ok 100 numbers

Test #11:

score: 0
Accepted
time: 2ms
memory: 3752kb

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.517548582156
2119.674780139699
1638.601494195409
144.699689011414
1706.299211744529
2671.668018298681
1442.324859385014
2909.931270666027
5311.386353862803
7894.844203655953
2950.721437208196
1405.197279587167
8052.785977535973
436.084854128185
1910.190147123792
1597.007827156774
8923.079345158...

result:

ok 100 numbers

Test #12:

score: 0
Accepted
time: 2ms
memory: 3712kb

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.003943812650
344430.708764477039
597464.947160122258
57512.000021251275
180112.504983949339
254594.189465463647
13301.834367630940
246235.741341503874
17086.953736696310
168329.001188149394
580568.278437601170
120047.475965045275
24722.575937794184
252882.798719090421
366.882341145876
108187.7...

result:

ok 100 numbers

Test #13:

score: 0
Accepted
time: 0ms
memory: 3720kb

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.523773639151
126504.999518608851
57518.293697332947
318943.663702541675
169769.250005668790
1497.133893067349
23459.324991965075
853.347816095363
28.351411845904
7526.106524036451
36705.816569039845
575.015321675223
4025.084882224933
31458.023666467034
316549.014556987683
52928.370889344403
13639...

result:

ok 100 numbers

Test #14:

score: 0
Accepted
time: 2ms
memory: 3656kb

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.584562910684
404181.388824374248
311311.528917577995
271785.624537060459
319158.191839094113
77725.025543495048
103690.241569289945
33781.004277552200
16708.608350188833
262422.768227149071
176381.843093329762
159818.483940375307
451836.634220813617
291664.040180887799
406095.266612404632
5914...

result:

ok 100 numbers