Пожалуйста помогите Link
№ | Пользователь | Рейтинг |
---|---|---|
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 | Um_nik | 163 |
3 | maomao90 | 162 |
3 | atcoder_official | 162 |
5 | adamant | 159 |
6 | -is-this-fft- | 158 |
7 | awoo | 157 |
8 | TheScrasse | 154 |
9 | Dominater069 | 153 |
9 | nor | 153 |
Название |
---|
Где можно сдать?
Click
Спасибо!
log2(10^12)<=40, можно использовать meet-in-the-middle.
можно подробней?
cnt[x][bit] — количество чисел в которых х-ый бит равен bit(0 или 1).
Давайте обозначим функцию f(x) как сумму , где 1 ≤ i ≤ n
Как найти f(x) за log :
Перебераем бит, j, от 1 до 40 (240 > 1012). И добавляем ответу где b, j-ый бит числа x.
Медленное решение: Перебераем маску x(0 ≤ x ≤ 240), если f(x) равен S тогда выводим x.
Оптимизируем с помощью meet-in-the-middle. Считаем первую половину, т.e. сохраняем значения. Для второй половины ищем ответ из сохраненных значений.
Код
Спасибо. Не знаете где можно сдать?
Click
Спасибо!
Более понятная реализация, где delta[b][i] сразу же обозначает разницу которую сделает установление i-того бита x-а на b: