Submission #947195

#TimeUsernameProblemLanguageResultExecution timeMemory
947195lulwpopCloud Computing (CEOI18_clo)C++14
54 / 100
350 ms1872 KiB
#include <bits/stdc++.h> #define fr first #define sc second #define all(x) (x).begin(), (x).end() #define pw(x) (1ll << x) #define pb push_back #define endl '\n' #define sz(x) (int)((x).size()) #define vec vector using namespace std; template <typename T> inline bool umin (T &a, const T &b) { if (a > b) { a = b; return 1; } return 0; } template <typename T> inline bool umax (T &a, const T &b) { if (a < b) { a = b; return 1; } return 0; } typedef long double ld; typedef long long ll; typedef unsigned long long ull; typedef pair <int, int> pii; inline void solve () { int n; cin >> n; vector <array <long long, 4>> ful; vector <long long> c (n), f (n), v (n); for (int i = 0; i < n; ++i) { cin >> c[i] >> f[i] >> v[i]; ful.pb({f[i], 0, c[i], v[i]}); } int m; cin >> m; vector <long long> qc (m), qf (m), qv (m); for (int i = 0; i < m; ++i) { cin >> qc[i] >> qf[i] >> qv[i]; ful.pb({qf[i], 1, qc[i], qv[i]}); } const int MX = 60 * n + 51; // const int MX = 10; vector <ll> dp (MX, -2e18); dp[0] = 0; sort(all(ful)); while (sz(ful)) { auto [f, type, c, v] = ful.back(); if (type == 0) { for (int i = MX - c; i >= 0; --i) { // cout << i << " " << dp[i] << " " << v << " " << dp[i + c] << endl; umax(dp[i + c], dp[i] - v); // cout << i << " " << dp[i] << " " << v << " " << dp[i + c] << endl; } } else { for (int i = c; i < MX; ++i) { // cout << i << " " << dp[i] << " " << v << " " << dp[i - c] << endl; umax(dp[i - c], dp[i] + v); // cout << i << " " << dp[i] << " " << v << " " << dp[i - c] << endl; } } ful.pop_back(); } // for (auto i : dp) cout << i << " "; cout << endl; cout << *max_element(all(dp)); } signed main () { ios_base::sync_with_stdio(0); cin.tie(0); cout.tie(0); int t = 1; // cin >> t; while (t--) solve(); return 0; }

Compilation message (stderr)

clo.cpp: In function 'void solve()':
clo.cpp:41:14: warning: structured bindings only available with '-std=c++17' or '-std=gnu++17'
   41 |         auto [f, type, c, v] = ful.back();
      |              ^
#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...