Submission #706007

#TimeUsernameProblemLanguageResultExecution timeMemory
706007lukameladzeKnapsack (NOI18_knapsack)C++14
100 / 100
80 ms30808 KiB
# include <bits/stdc++.h> using namespace std; #define f first #define s second #define int long long #define pii pair <int, int> #define pb push_back const int N = 1e6 + 5; int t,n,w[N],s,sum[N],dp[N],v[N],k[N]; vector <pii> vec[N]; main() { std::ios_base::sync_with_stdio(false),cin.tie(0),cout.tie(0); cin>>s>>n; for (int i = 1; i <= n; i++) { cin>>v[i]>>w[i]>>k[i]; vec[w[i]].pb({v[i], k[i]}); sum[w[i]] += k[i]; } int ans = 0; for (int i = 1; i <= s; i++) { sort(vec[i].rbegin(),vec[i].rend()); int cur = 0, cnt = 0; for (int j = 1; j <= min(s / i, sum[i]); j++) { for (int k = s; k >= i; k--) { dp[k] = max(dp[k], dp[k - i] + vec[i][cur].f); ans = max(ans, dp[k]); } cnt++; if (cnt == vec[i][cur].s) cur++, cnt = 0; } } cout<<ans<<"\n"; }

Compilation message (stderr)

knapsack.cpp:11:1: warning: ISO C++ forbids declaration of 'main' with no type [-Wreturn-type]
   11 | main() {
      | ^~~~
#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...