i'm trying to solve this problem but i can't find any algorithm better than O(n^2) !
your help will be greatly appreciated.
# | 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 |
Name |
---|
Auto comment: topic has been updated by Mid0 (previous revision, new revision, compare).
Consider some substring S[i...j]. Let parity[K] for 0<=K<=9 be the parity of the number of occurrences of digit K in subtring S[i...j]. Notice that the substring will be a palindrome if and only if parity[K] is 0 for all K or there is only one K for which parity[K] is 1 and parity[K] is 0 for all other Ks.
Having that in mind, we will loop from 1 to N and at each step we will find the number of those palindromes ending at the current position i. In order to do that, let parity[K] be the described parity for digit K in substring S[1...i]. Consider some j (1<=j<=i). Substring S[j...i] can be made a palindrome if all parities for position j-1 are the same as the parities for position i or there is only one difference.
For each position, we can store the parities as a bitmask with 10 bits and that way we can find the answer quickly. Check my code for more details: http://ideone.com/1grO2A :)
got it , nice usage of bitwise , thank you :)