Пожалуйста помогите Link
№ | Пользователь | Рейтинг |
---|---|---|
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 |
Страны | Города | Организации | Всё → |
№ | Пользователь | Вклад |
---|---|---|
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 |
Название |
---|
Где можно сдать?
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: