I am not getting idea on the problem of dynamic programming. I am posting the link of question. Someone please help. Thnaks in advamce.Here is the link
# | 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 | 167 |
2 | -is-this-fft- | 165 |
3 | Um_nik | 160 |
3 | atcoder_official | 160 |
5 | djm03178 | 158 |
6 | Dominater069 | 156 |
7 | adamant | 153 |
8 | luogu_official | 151 |
8 | awoo | 151 |
10 | TheScrasse | 146 |
I am not getting idea on the problem of dynamic programming. I am posting the link of question. Someone please help. Thnaks in advamce.Here is the link
Name |
---|
Here is my idea for O(N2) dynamic programming solution (got AC):
Let our state be:
F[L][R] = the minimum amount of characters to insert to make the substring SLSL + 1...SR a palindrome.
Obviously the answer would be F[1][n]. Now let's come up with a recursive formula:
Suppose that we are trying to find the answer for some F[L][R]. We can see that at least one of the following three cases will always be true for any solution:
1) We add a character to the end to match SL — in that case, after that one move, we end up trying to make SL + 1...SR a palindrome. So the outcome of this case is F[L + 1][R] + 1.
2) We add a character to the beginning to match SR — in that case, after that one move, we end up trying to make SL...SR - 1 a palindrome. So the outcome of this case is F[L][R - 1] + 1
3) We match SL with SR. This is only possible if they are equal and in that case we have the outcome of F[L + 1][R - 1]
This gives us a simple formula:
F[L][R] = MIN(F[L + 1][R] + 1, F[L][R - 1] + 1) for SL ≠ SR
F[L][R] = MIN(F[L + 1][R] + 1, F[L][R - 1] + 1, F[L + 1][R - 1]) for SL = SR
Base cases are for R ≤ L, F[L][R] = 0
The complexity is O(N2) for both time and memory. Hope that helps :)