OpenFIPI 2.0
5
5
246c36
На вход алгоритма подаётся натуральное число N. Алгоритм строит по нему новое число R следующим образом.
1. Строится двоичная запись числа N.
2. Далее эта запись обрабатывается по следующему правилу:
а) если число N делится на 3, то к этой записи дописываются три последние двоичные цифры;
б) если число N на 3 не делится, то остаток от деления умножается на 3, переводится в двоичную запись и дописывается в конец числа.
Полученная таким образом запись является двоичной записью искомого числа R.
3. Результат переводится в десятичную систему и выводится на экран.
Например, для исходного числа 1210 = 11002 результатом является число 11001002 = 10010, а для исходного числа 410 = 1002 это число 100112 = 1910.
Укажите максимальное число R, не превышающее 208, которое может быть получено с помощью описанного алгоритма. В ответе запишите это число в десятичной системе счисления.
199
m = []
for n in range(4,1000):
b = f'{n:b}'
if n%3 == 0:
b = b + b[-3] + b[-2] + b[-1]
else:
b = b + f'{n%3*3:b}'
r = int(b,2)
if r<208:
m.append(r)
print(max(m))
Просмотреть отправленные ответы 246c36