Алгоритм получает на вход натуральное число N > 1 и строит по нему новое число R следующим образом:
1. Строится двоичная запись числа N.
2. Вычисляется количество единиц, стоящих на чётных местах в двоичной записи числа N без ведущих нулей, и количество нулей, стоящих на нечётных местах. Места отсчитываются слева направо (от старших разрядов к младшим, начиная с единицы).
3. Результатом работы алгоритма становится модуль разности полученных двух чисел.
Пример. Дано число N = 39. Алгоритм работает следующим образом:
1. Строится двоичная запись: 3910 = 1001112.
2. Выделяем единицы на чётных и нули на нечётных местах: 100111. На чётных местах стоят две единицы, на нечётных — один ноль.
3. Модуль разности
Результат работы алгоритма R = 1.
При каком наименьшем N в результате работы алгоритма получится R = 4?
Заметим, что искомое число в двоичной системе счисления начинается с единицы. Поскольку считается количество единиц на чётных местах и количество нулей на нечётных местах, а отсчёт номера позиций ведётся слева направо, начиная с единицы, искомое число должно состоять только из единиц. Следовательно, искомое число — 111111112 = 25510.
Ответ: 255.
Приведём решение на языке Python.
for n in range(2, 10000):
s = bin(n)[2:] # перевод в двоичную систему
sum_one = 0
sum_zero = 0
for i in range(len(s)):
if i % 2 != 0 and s[i] == "1":
sum_one += 1
elif i % 2 == 0 and s[i] == "0":
sum_zero += 1
if abs(sum_one - sum_zero) == 4:
print(n)
break

