# | User | Rating |
---|---|---|
1 | jiangly | 3976 |
2 | tourist | 3815 |
3 | jqdai0815 | 3682 |
4 | ksun48 | 3614 |
5 | orzdevinwang | 3526 |
6 | ecnerwala | 3514 |
7 | Benq | 3482 |
8 | hos.lyric | 3382 |
9 | gamegame | 3374 |
10 | heuristica | 3357 |
# | User | Contrib. |
---|---|---|
1 | cry | 169 |
2 | -is-this-fft- | 166 |
3 | Um_nik | 161 |
3 | atcoder_official | 161 |
5 | djm03178 | 157 |
6 | Dominater069 | 156 |
7 | adamant | 154 |
8 | luogu_official | 152 |
9 | awoo | 151 |
10 | TheScrasse | 147 |
Name |
---|
as i mentioned before on the main blog comment, the given test data is special, and i'm not sure if there's algorithm with less than O(N^2) complexity on the worst case
There is an algorithm with linear complexity :). If you managed to pass all tests with O(n^2) complexity it was rather undesirable :P. There are two tricky observations in this task, which can be easily proven:
If we want to maximize only the ratio, not the length, we can consider substrings with only one bad letter.
If length is also taken into cosideration, we should additionally check if there exists a substring of form 0000110000 (k zeros, 2 ones and k zeros), where k is the best ratio. Given that observations we can easily come up with a linear algorithm.
P.S. At the beginning the ratio of T's and C's to the A's and G's was near 1. Later, in order to make inputs better compress, this ratio were highly lowered. P.S.2 I've come up with an idea for this problem (others were monsoon's), hope you enjoyed it :).