Submission #866262

#TimeUsernameProblemLanguageResultExecution timeMemory
866262dio_2Balloons (CEOI11_bal)C++17
50 / 100
2058 ms7092 KiB
#include<bits/stdc++.h> using namespace std; using ld = long double; using ll = long long; int main(){ ios::sync_with_stdio(false); cin.tie(nullptr); int N; cin >> N; vector<ll> x(N), r(N); vector<ld> ans(N); for(int i = 0;i < N;i++){ cin >> x[i] >> r[i]; } ans[0] = r[0]; cout << fixed << setprecision(3) << ans[0] << '\n'; #define X first #define Y second auto d = [&](pair<ld, ld> A, pair<ld, ld> B)->ld{ return (A.X-B.X)*(A.X-B.X)+(A.Y-B.Y)*(A.Y-B.Y); }; /* 3 0 9 8 1 13 7 */ auto Calc = [&](int i, int j)->ld{ ld radius_j = ans[j]; pair<ld, ld> centre_j = {x[j], radius_j}; ld lo = 0, hi = r[i], mid; //~ for(int rep = 0;rep < 70;++rep){ //~ mid = (lo + hi) / 2; //~ ld radius_i = mid; //~ pair<ld, ld> centre_i = {x[i], radius_i}; //~ if(d(centre_i, centre_j) >= (radius_i + radius_j) * (radius_i + radius_j)) //~ lo = mid; //~ else //~ hi = mid; //~ } //~ return (lo + hi) / 2; return (ld(x[i]*x[i]+x[j]*x[j]-2*x[i]*x[j])) / (4 * radius_j); }; for(int i = 1;i < N;i++){ ld use = r[i]; for(int j = 0;j < i;j++){ use = min(use, Calc(i, j)); } ans[i] = use; cout << fixed << setprecision(3) << use << '\n'; } return 0; }

Compilation message (stderr)

bal.cpp: In lambda function:
bal.cpp:38:16: warning: variable 'centre_j' set but not used [-Wunused-but-set-variable]
   38 |   pair<ld, ld> centre_j = {x[j], radius_j};
      |                ^~~~~~~~
bal.cpp:40:6: warning: unused variable 'lo' [-Wunused-variable]
   40 |   ld lo = 0, hi = r[i], mid;
      |      ^~
bal.cpp:40:14: warning: unused variable 'hi' [-Wunused-variable]
   40 |   ld lo = 0, hi = r[i], mid;
      |              ^~
bal.cpp:40:25: warning: unused variable 'mid' [-Wunused-variable]
   40 |   ld lo = 0, hi = r[i], mid;
      |                         ^~~
bal.cpp: In function 'int main()':
bal.cpp:26:7: warning: variable 'd' set but not used [-Wunused-but-set-variable]
   26 |  auto d = [&](pair<ld, ld> A, pair<ld, ld> B)->ld{
      |       ^
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...