Пожалуйста помогите Link
№ | Пользователь | Рейтинг |
---|---|---|
1 | tourist | 3993 |
2 | jiangly | 3743 |
3 | orzdevinwang | 3707 |
4 | Radewoosh | 3627 |
5 | jqdai0815 | 3620 |
6 | Benq | 3564 |
7 | Kevin114514 | 3443 |
8 | ksun48 | 3434 |
9 | Rewinding | 3397 |
10 | Um_nik | 3396 |
Страны | Города | Организации | Всё → |
№ | Пользователь | Вклад |
---|---|---|
1 | cry | 167 |
2 | Um_nik | 163 |
3 | maomao90 | 162 |
3 | atcoder_official | 162 |
5 | adamant | 159 |
6 | -is-this-fft- | 158 |
7 | awoo | 155 |
8 | TheScrasse | 154 |
9 | Dominater069 | 153 |
10 | djm03178 | 152 |
Название |
---|
Где можно сдать?
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: