Submission #467351

#TimeUsernameProblemLanguageResultExecution timeMemory
467351idk321Sure Bet (CEOI17_sure)C++17
0 / 100
0 ms320 KiB
#include <bits/stdc++.h> using namespace std; typedef long long ll; const int N = 100005; double odds [2][N]; int main() { ios::sync_with_stdio(0); cin.tie(0); int n; cin >> n; for (int i = 0; i < n; i++) { cin >> odds[0][i] >> odds[1][i]; } sort(odds[0], odds[0] + n, greater<double>()); sort(odds[1], odds[1] + n, greater<double>()); double res = 0; double val1 = 0; double val2 = 0; int j = -1; for (int i = 0; i < n; i++) { val1 += odds[0][i]; while (j + 1 < n && val2 < val1) { j++; val2 += odds[1][j]; } int cost = (i + 1) + (j + 1); res = max(res, min(val1, val2) - cost); if (val2 > val1) { val2 -= odds[1][j]; j--; } cost--; res = max(res, min(val1, val2) - cost); } cout << fixed << setprecision(4) << res << "\n"; } /* 4 1.4 3.7 1.2 2 1.6 1.4 1.9 1.5 */
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...