QOJ.ac

QOJ

IDProblemSubmitterResultTimeMemoryLanguageFile sizeSubmit timeJudge time
#304665#8007. Egg Drop Challengeucup-team180#WA 65ms8180kbC++174.4kb2024-01-13 23:26:342024-01-13 23:26:34

Judging History

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

  • [2024-01-13 23:26:34]
  • 评测
  • 测评结果:WA
  • 用时:65ms
  • 内存:8180kb
  • [2024-01-13 23:26:34]
  • 提交

answer

#include <bits/stdc++.h>
using namespace std;
const double INF = 1000000000000000000;
template <typename T1, typename T2, typename F>
struct abstract_li_chao_tree{
  int N;
  vector<T1> x;
  vector<F> ST;
  abstract_li_chao_tree(){
  }
  abstract_li_chao_tree(const vector<T1> &x2){
    x = x2;
    sort(x.begin(), x.end());
    int N2 = x.size();
    assert(N2 > 0);
    N = 1;
    while (N < N2){
      N *= 2;
    }
    x.resize(N);
    for (int i = N2; i < N; i++){
      x[i] = x[N2 - 1];
    }
    ST = vector<F>(N * 2 - 1);
  }
  void line_add(F f, int i, int l, int r){
    T2 la = f.get(x[l]);
    T2 lb = ST[i].get(x[l]);
    T2 ra = f.get(x[r - 1]);
    T2 rb = ST[i].get(x[r - 1]);
    if (la >= lb && ra >= rb){
      return;
    } else if (la <= lb && ra <= rb){
      ST[i] = f;
    } else {
      int m = (l + r) / 2;
      T2 ma = f.get(x[m]);
      T2 mb = ST[i].get(x[m]);
      if (ma < mb){
        swap(f, ST[i]);
        swap(la, lb);
        swap(ra, rb);
      }
      if (la < lb){
        line_add(f, i * 2 + 1, l, m);
      }
      if (ra < rb){
        line_add(f, i * 2 + 2, m, r);
      }
    }
  }
  void line_add(F f){
    line_add(f, 0, 0, N);
  }
  void segment_add(int L, int R, F f, int i, int l, int r){
    if (r <= L || R <= l){
      return;
    } else if (L <= l && r <= R){
      line_add(f, i, l, r);
    } else {
      int m = (l + r) / 2;
      segment_add(L, R, f, i * 2 + 1, l, m);
      segment_add(L, R, f, i * 2 + 2, m, r);
    }
  }
  void segment_add(T1 l, T1 r, F f){
    int pl = lower_bound(x.begin(), x.end(), l) - x.begin();
    int pr = lower_bound(x.begin(), x.end(), r) - x.begin();
    segment_add(pl, pr, f, 0, 0, N);
  }
  T2 get(T1 x2){
    int p = lower_bound(x.begin(), x.end(), x2) - x.begin();
    assert(p < x.size());
    p += N - 1;
    T2 ans = INF;
    ans = min(ans, ST[p].get(x2));
    while (p > 0){
      p = (p - 1) / 2;
      ans = min(ans, ST[p].get(x2));
    }
    return ans;
  }
};
struct f1{
  double a;
  long long b;
  f1(): a(INF), b(0){
  }
  f1(double a, long long b): a(a), b(b){
  }
  double get(long long x){
    if (b - 2 * x >= 0){
      return a + sqrt(b - 2 * x);
    } else {
      return INF;
    }
  }
};
struct f2{
  double a;
  long long b;
  f2(): a(INF), b(INF){
  }
  f2(double a, long long b): a(a), b(b){
  }
  double get(long long x){
    if (x - 2 * b >= 0){
      return a - sqrt(x - 2 * b);
    } else {
      return INF * 2;
    }
  }
};
int main(){
  cout << fixed << setprecision(20);
  int n;
  cin >> n;
  vector<long long> h(n), v(n), u(n);
  for (int i = 0; i < n; i++){
    cin >> h[i] >> v[i] >> u[i];
  }
  vector<long long> V(n), U(n);
  for (int i = 0; i < n; i++){
    V[i] = v[i] * v[i] + 2 * h[i];
    U[i] = u[i] * u[i] + 2 * h[i];
  }
  vector<double> dp(n, INF);
  dp[n - 1] = 0;
  auto dc = [&](auto dc, int L, int R) -> void {
    if (R - L <= 1){
      return;
    }
    int m = (L + R) / 2;
    dc(dc, m, R);
    vector<pair<long long, int>> P(R - L);
    for (int i = L; i < m; i++){
      P[i - L] = make_pair(U[i], i);
    }
    for (int i = m; i < R; i++){
      P[i - L] = make_pair(V[i], i);
    }
    sort(P.begin(), P.end());
    vector<double> A(R - m);
    for (int i = m; i < R; i++){
      A[i - m] = dp[i] - v[i];
    }
    vector<long long> x1(m - L);
    for (int i = L; i < m; i++){
      x1[i - L] = h[i];
    }
    abstract_li_chao_tree<long long, double, f1> LCT1(x1);
    for (int i = 0; i < R - L; i++){
      int p = P[i].second;
      if (p >= m){
        LCT1.line_add(f1(A[p - m], V[p]));
      } else {
        dp[p] = min(dp[p], LCT1.get(h[p]));
      }
    }
    reverse(P.begin(), P.end());
    vector<double> B(m - L, INF);
    vector<long long> x2(m - L);
    for (int i = L; i < m; i++){
      x2[i - L] = U[i];
    }
    abstract_li_chao_tree<long long, double, f2> LCT2(x2);
    for (int i = 0; i < R - L; i++){
      int p = P[i].second;
      if (p >= m){
        LCT2.segment_add(h[p] * 2, INF * 2, f2(dp[p], h[p]));
      } else {
        B[p - L] = min(B[p - L], LCT2.get(U[p]));
      }
    }
    for (int i = L; i < m; i++){
      dp[i] = min(dp[i], B[i - L] + u[i]);
    }
    dc(dc, L, m);
  };
  dc(dc, 0, n);
  if (dp[0] >= INF / 2){
    cout << -1 << endl;
  } else {
    cout << dp[0] << endl;
  }
}

Details

Tip: Click on the bar to expand more detailed information

Test #1:

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

input:

5
2 1 7
14 6 4
18 1 7
21 2 5
28 4 10

output:

6.00000000000000000000

result:

ok found '6.0000000', expected '6.0000000', error '0.0000000'

Test #2:

score: 0
Accepted
time: 1ms
memory: 3824kb

input:

2
1 1 4
10 5 1

output:

-1

result:

ok found '-1.0000000', expected '-1.0000000', error '-0.0000000'

Test #3:

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

input:

10
16 1 6
27 8 8
32 4 8
51 6 6
62 5 10
81 5 9
84 10 6
92 1 2
94 9 6
96 7 9

output:

12.85983097695973675911

result:

ok found '12.8598310', expected '12.8598310', error '0.0000000'

Test #4:

score: 0
Accepted
time: 1ms
memory: 3792kb

input:

100
96 20 27
119 4 12
270 5 24
594 3 10
614 8 19
688 7 5
798 14 36
983 2 27
1057 20 21
1266 6 30
1388 18 18
1520 2 12
1809 4 26
1960 17 40
2137 8 10
2274 3 30
2320 14 34
2357 6 2
2392 12 5
2518 14 2
2681 10 29
2701 9 15
2865 3 38
3008 9 17
3021 6 39
3194 9 24
3212 14 12
3233 19 3
3628 18 6
3772 1 37...

output:

-1

result:

ok found '-1.0000000', expected '-1.0000000', error '-0.0000000'

Test #5:

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

input:

1000
370 20 90
1387 5 16
2315 1 25
3657 24 78
4597 11 42
5558 11 95
6044 12 80
6577 15 40
7746 12 87
7978 22 63
9306 23 72
9957 9 51
10182 27 36
10895 12 51
12595 28 58
12924 5 4
13166 11 36
15206 9 66
15938 18 70
17654 4 71
19189 2 6
19903 22 77
20032 30 57
20493 3 51
23719 3 65
24490 17 31
25831 2...

output:

-1

result:

ok found '-1.0000000', expected '-1.0000000', error '-0.0000000'

Test #6:

score: 0
Accepted
time: 20ms
memory: 5664kb

input:

10000
8007 22 578
11024 369 551
19219 226 631
49583 226 629
72385 86 271
77173 257 574
78655 25 16
83483 301 820
100132 101 466
104988 267 221
105671 361 245
116034 132 421
127581 152 516
134693 356 423
137403 344 24
145224 29 785
177093 52 151
177351 98 252
187858 59 361
198082 220 525
200929 190 4...

output:

181483.42538348550442606211

result:

ok found '181483.4253835', expected '181483.4253835', error '0.0000000'

Test #7:

score: 0
Accepted
time: 25ms
memory: 5724kb

input:

10000
13126 270 1489
26908 146 526
31808 317 439
37014 228 17
38133 343 524
42564 33 1534
52311 365 330
55177 188 639
56700 324 125
64335 252 1502
72034 342 210
74586 141 1355
74684 192 540
81341 221 668
83265 290 976
100618 352 1480
106923 306 201
111018 317 876
122964 105 709
136538 271 710
139072...

output:

111027.67035201867111027241

result:

ok found '111027.6703520', expected '111027.6703520', error '0.0000000'

Test #8:

score: 0
Accepted
time: 20ms
memory: 5752kb

input:

10000
1246 196 852
5373 81 693
11983 280 51
14659 300 364
19938 49 374
33283 163 585
52313 358 720
57071 189 416
58853 191 8
60880 375 114
63011 252 938
65547 65 213
77644 318 117
82898 272 474
94163 268 835
100416 218 534
102725 304 948
123894 396 89
136799 167 571
144790 7 538
148178 309 751
15246...

output:

166264.59040048421593382955

result:

ok found '166264.5904005', expected '166264.5904005', error '0.0000000'

Test #9:

score: -100
Wrong Answer
time: 65ms
memory: 8180kb

input:

20000
4005279410235 932144073 846501600
246203983392304 987850080 1000000000
253308227561395 949883486 905152286
304849760557616 1000000000 900558667
341777344771231 1000000000 958632875
344792803914679 904989873 925199910
374645189833605 1000000000 903348322
413848740943401 1000000000 905002905
475...

output:

1446237702.61286783218383789062

result:

wrong answer 1st numbers differ - expected: '1445918117.8858886', found: '1446237702.6128678', error = '0.0002210'