На вход алгоритма подаётся натуральное число N. Алгоритм строит по нему новое число R следующим образом.
1. Строится двоичная запись числа N.
2. Далее эта запись обрабатывается по следующему правилу:
а) если сумма цифр в двоичной записи числа чётная, то к этой записи справа
б) если сумма цифр в двоичной записи числа нечётная, то к этой записи справа
Полученная таким образом запись является двоичной записью искомого числа R.
Например, для исходного числа 610 = 1102 результатом является число 10002 = 810, а для исходного числа 410 = 1002 результатом является число 11012 = 1310.
Укажите минимальное число N, после обработки которого с помощью этого алгоритма получается число R,
Приведём решение на языке PascalABC.
var
s: string;
i, min: integer;
num: real;
function CalculateNumber(n: integer): integer;
begin
s := '';
repeat
s := s + IntToStr(n mod 2);
n := n div 2;
until n = 0;
s := ReverseString(s);
if (s.CountOf('1') mod 2) = 0 then begin
Delete(s, 1, 2);
s := '10' + s + '0';
end
else begin
Delete(s, 1, 2);
s := '11' + s + '1';
end;
num := 0;
for i:integer := 1 to s.Length do begin
num := num + StrToInt(s[i]) * Power(2, s.Length - i);
end;
CalculateNumber := round(num);
end;
begin
for i := 1 to 100 do
if CalculateNumber(i) > 40 then begin
writeln(i);
break;
end;
end.
Ответ: 16.
Приведём другое решение на языке Python.
a = []
for n in range(1, 100):
s = bin(n)[2:] # перевод в двоичную систему
s = str(s)
if s.count('1') % 2 == 0:
s = "10" + s[2:] + '0'
else:
s = "11" + s[2:] + "1"
r = int(s, 2) # перевод в десятичную систему
if r > 40:
a.append(n)
print(min(a))

