結果
問題 |
No.2495 Three Sets
|
ユーザー |
![]() |
提出日時 | 2023-10-06 21:51:12 |
言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
結果 |
WA
|
実行時間 | - |
コード長 | 1,523 bytes |
コンパイル時間 | 3,870 ms |
コンパイル使用メモリ | 233,120 KB |
実行使用メモリ | 6,948 KB |
最終ジャッジ日時 | 2024-07-26 16:00:38 |
合計ジャッジ時間 | 5,309 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge3 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 5 WA * 13 |
ソースコード
#include <bits/stdc++.h> using namespace std; #include <atcoder/all> using namespace atcoder; #define rep(i, n) for(int i=0;i<(n);++i) #define rep1(i, n) for(int i=1;i<=(n);i++) #define ll long long using mint = modint998244353; using P = pair<ll,ll>; using lb = long double; using T = tuple<ll, ll, ll>; #ifdef LOCAL # include <debug_print.hpp> # define dbg(...) debug_print::multi_print(#__VA_ARGS__, __VA_ARGS__) #else # define dbg(...) (static_cast<void>(0)) #endif int main() { vector<int> n(3); rep(i,3) cin >> n[i]; vector<priority_queue<int>> qs(3); vector<ll> sz(3); vector<ll> sum(3); rep(i,3){ rep(j,n[i]){ int a; cin >> a; if(a>=0) { sum[i] += a; sz[i]++; } else qs[i].push(a); } } ll ans = 0; rep(i,3){ ans += sum[i] * sz[(i+1)%3]; } dbg(ans); while(true){ bool upd = false; rep(i,3){ if(qs[i].empty()) continue; int u = qs[i].top(); sum[i] += u; sz[i]++; ll tmp = 0; rep(j,3){ tmp += sum[j] * sz[(j+1)%3]; } if(tmp>=ans) { ans = tmp; upd = true; qs[i].pop(); } else{ sum[i] -= u; sz[i]--; } } dbg(upd); if(!upd) break; } cout << ans << endl; return 0; }