제출 #596012

#제출 시각아이디문제언어결과실행 시간메모리
596012HanksburgerCloud Computing (CEOI18_clo)C++17
54 / 100
1082 ms1956 KiB
#include <bits/stdc++.h> using namespace std; pair<pair<long long, long long>, long long> a[4005]; long long dp[100005], tmp[100005]; int main() { ios::sync_with_stdio(0); cin.tie(0); cout.tie(0); long long n, m; cin >> n; for (long long i=1; i<=n; i++) { cin >> a[i].second >> a[i].first.first >> a[i].first.second; a[i].first.second*=-1; } cin >> m; for (long long i=n+1; i<=n+m; i++) { cin >> a[i].second >> a[i].first.first >> a[i].first.second; a[i].second*=-1; } sort(a+1, a+n+m+1, greater<pair<pair<long long, long long>, long long> >()); for (long long i=1; i<=1e5; i++) dp[i]=-1e18; for (long long i=1; i<=n+m; i++) { for (long long j=0; j<=1e5; j++) { if (j-a[i].second>=0 && j-a[i].second<=1e5) tmp[j]=max(dp[j], dp[j-a[i].second]+a[i].first.second); else tmp[j]=dp[j]; } // cout << "i=" << i << ": " << a[i].second << ' ' << a[i].first.first << ' ' << a[i].first.second << '\n'; for (long long j=0; j<=1e5; j++) { dp[j]=tmp[j]; // if (j<=15) // cout << dp[j] << ' '; } // cout << '\n'; } long long ans=0; for (long long i=0; i<=1e5; i++) ans=max(ans, dp[i]); cout << ans; 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...