please any one solved this problem explain the idea of it please.
thanks in advance.
thanks in advance.
№ | Пользователь | Рейтинг |
---|---|---|
1 | tourist | 4009 |
2 | jiangly | 3823 |
3 | Benq | 3738 |
4 | Radewoosh | 3633 |
5 | jqdai0815 | 3620 |
6 | orzdevinwang | 3529 |
7 | ecnerwala | 3446 |
8 | Um_nik | 3396 |
9 | ksun48 | 3390 |
10 | gamegame | 3386 |
Страны | Города | Организации | Всё → |
№ | Пользователь | Вклад |
---|---|---|
1 | cry | 167 |
2 | maomao90 | 163 |
2 | Um_nik | 163 |
4 | atcoder_official | 161 |
5 | adamant | 159 |
6 | -is-this-fft- | 158 |
7 | awoo | 157 |
8 | TheScrasse | 154 |
9 | nor | 153 |
9 | Dominater069 | 153 |
Название |
---|
let us consider first that the card is also an envelope, now the problem is what is the maximum number of envlopes that can be stacked in each other and the inner envelope is the card
the recursive formula is like that
Sol[i] = Max ( sol[k] + 1 , Sol[i] )
where k is every envelope that envelope i can be stacked in
so it will be like that
for(int k = 0; k < N;k++)
{
if(Cards[i][0] < Cards[k][0] && Cards[i][1] < Cards[k][1] && DP[i] < Solve(k)+1)
{
DP[i] = Solve(k)+1;
}
}
i got memory limit exceeded cuz i precomputed this step first ....but in practice session i removed the precomputing step and I got AC