# | User | Rating |
---|---|---|
1 | jiangly | 4039 |
2 | tourist | 3841 |
3 | jqdai0815 | 3682 |
4 | ksun48 | 3590 |
5 | ecnerwala | 3542 |
6 | Benq | 3535 |
7 | orzdevinwang | 3526 |
8 | gamegame | 3477 |
9 | heuristica | 3357 |
10 | Radewoosh | 3355 |
# | User | Contrib. |
---|---|---|
1 | cry | 168 |
2 | -is-this-fft- | 165 |
3 | atcoder_official | 160 |
3 | Um_nik | 160 |
5 | djm03178 | 157 |
6 | Dominater069 | 156 |
7 | adamant | 153 |
8 | luogu_official | 152 |
9 | awoo | 151 |
10 | TheScrasse | 147 |
Name |
---|
300^4 complexity will definitely not get you accepted. Lose the loop inside the dp state, convert the loop into two state calls as taking the current coin and not taking it. Also, why are you clearing dp array for each case? You only need to do it once. For 'tot' parameter in dp state, you went backwards. Do the same for 'term' parameter.
Hmm.. Thanks.
But I m not clear with recursion's complexity.
Ok, crux of it goes like this: the number of parameters you have for a single dp state, multiply their worst cast limit together. Plus if you have inside loops inside the dp state, those factor in too. You have 3 parameters here, namely 'ind', 'tot' and 'term' whose maximum values can be 300. So we get 300^3 by multiplying them. You also have a loop going on inside the dp state which adds an iteration of 300 at most. That's how you get 300^4 or O(N^4) complexity.