Submission #697030

#TimeUsernameProblemLanguageResultExecution timeMemory
697030hazzleTable Tennis (info1cup20_tabletennis)C++17
15 / 100
3086 ms852 KiB
#include <bits/stdc++.h> #include <ext/pb_ds/assoc_container.hpp> #include <ext/pb_ds/tree_policy.hpp> using namespace std; using namespace __gnu_pbds; #define fi first #define se second #define all(m) (m).begin(), (m).end() #define rall(m) (m).rbegin(), (m).rend() #define vec vector #define sz(a) (int) (a).size() #define mpp make_pair #define mtt make_tuple typedef long long ll; typedef long double ld; typedef unsigned long long ull; typedef pair <int, int> pii; typedef tuple <int, int, int> tui; template <typename T> bool umin(T &a, T b) { return a > b ? a = b, 1 : 0; } template <typename T> bool umax(T &a, T b) { return a < b ? a = b, 1 : 0; } mt19937 rng((uint64_t) new char); int solve(){ int n, k; cin >> n >> k; int z = n + k; vec <int> a(z); for (auto &i: a) cin >> i; auto ok = [&](int ai, int x){ if (2 * ai == x) return false; int p = lower_bound(all(a), x - ai) - a.begin(); return p != z && a[p] + ai == x; }; auto get_ans = [&](int x){ sort(all(a)); vec <int> ans; int pl = 0, pr = z - 1; while(sz(ans) < n){ assert(pl < pr); if (a[pl] + a[pr] == x){ ans.push_back(a[pl]); ans.push_back(a[pr]); ++pl, --pr; } else if (a[pl] + a[pr] < x) ++pl; else --pr; } sort(all(ans)); for (auto &i: ans) cout << i << " "; exit(0); }; if (n <= k){ for (int i = 0; i < z; ++i){ for (int j = i + 1; j < z; ++j){ int x = a[i] + a[j]; int cnt = 0; for (int l = 0; l < z; ++l){ cnt += ok(a[l], x); } if (cnt >= n) get_ans(x); } } return 0; } shuffle(all(a), rng); while(true){ int ai = a[rng() % z]; for (auto &aj: a){ int x = ai + aj, cnt = 1; for (int i = 0; i < min(n - 1, 2 * k); ++i){ cnt += ok(a[i], x); } if (cnt >= min(n, 2 * k + 1)) get_ans(x); } } return 0; } signed main(){ ios_base::sync_with_stdio(0); cin.tie(0); cout.tie(0); int tst = 1; //cin >> tst; while(tst--) solve(); return 0; }
#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...