Submission #1055359

#TimeUsernameProblemLanguageResultExecution timeMemory
10553591neKnapsack (NOI18_knapsack)C++14
17 / 100
1 ms488 KiB
/* * author : Apiram * created: 12.08.2024 23:08:11 */ #include<bits/stdc++.h> using namespace std; struct node{ long long v,w,k; }; int main(){ ios_base::sync_with_stdio(false); cin.tie(0); long long s,n;cin>>s>>n; vector<node>arr(n); for (long long i = 0;i<n;++i){ cin>>arr[i].v>>arr[i].w>>arr[i].k; } vector<long long>dp(s + 1,0); dp[0] = 0; long long ans = 0; for (long long i = 0;i<n;++i){ vector<long long>pos; vector<long long>new_dp = dp; for (long long k = 0;;++k){ if (arr[i].k < (1<<k))break; pos.push_back((1<<k)); arr[i].k-=(1<<k); } if (arr[i].k != 0)pos.push_back(arr[i].k); sort(pos.begin(),pos.end()); for (long long j = s;j>=0;--j){ if (dp[j] == -1)continue; for (auto x:pos){ if (j + x * arr[i].w > s)break; dp[j + x * arr[i].w] = max(dp[j + x * arr[i].w],dp[j] + arr[i].v * x); } } } sort(dp.begin(),dp.end()); cout<<dp.back()<<'\n'; return 0; }

Compilation message (stderr)

knapsack.cpp: In function 'int main()':
knapsack.cpp:21:12: warning: unused variable 'ans' [-Wunused-variable]
   21 |  long long ans = 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...