I was solving Book Shop of CSES DP section.
- I am getting TLE even after multiple attempts, Can you tell me how to optimize my TOP-DOWN approach.
- I have also replace 2-d array with 2-d vector but that is also getting TLE.
my code
# | User | Rating |
---|---|---|
1 | tourist | 3985 |
2 | jiangly | 3814 |
3 | jqdai0815 | 3682 |
4 | Benq | 3529 |
5 | orzdevinwang | 3526 |
6 | ksun48 | 3517 |
7 | Radewoosh | 3410 |
8 | hos.lyric | 3399 |
9 | ecnerwala | 3392 |
9 | Um_nik | 3392 |
# | User | Contrib. |
---|---|---|
1 | cry | 169 |
2 | maomao90 | 162 |
2 | Um_nik | 162 |
4 | atcoder_official | 161 |
5 | djm03178 | 158 |
6 | -is-this-fft- | 157 |
7 | adamant | 155 |
8 | awoo | 154 |
8 | Dominater069 | 154 |
10 | luogu_official | 150 |
CSES DP SECTION — Book Shop
#include "bits/stdc++.h"
using namespace std;
int dp[1001][100001];
vector <int >price, page;
int state(int index, int total)
{
if (index < 0) return 0;
if (dp[index][total] != -1) return dp[index][total];
int &ans = dp[index][total];
if (total >= price[index]) {
ans = page[index] + state(index - 1, total - price[index]);
}
ans = max(ans, state(index - 1, total));
return ans;
}
int main() {
ios::sync_with_stdio(false); cin.tie(nullptr);
int n, req; cin >> n >> req;
price.resize(n); page.resize(n);
for (auto &x : price) cin >> x;
for (auto &x : page) cin >> x;
memset(dp, -1, sizeof(dp));
cout << state(n - 1, req);
Name |
---|