Дан рекурсивный алгоритм: function f(n: integer): integer; begin if n < 5 then f: = f(n+3) + f(2*n) + f(3*n div 2) else f: = n + 2; end; чему будет равно значение, вычисленное алгоритмом при выполнении вызова f(3)?
Function F(n: integer): integer; begin Writeln('Вход с n=',n); if n < 5 then Result := F(n + 3) + F(2 * n) + F(3 * n div 2) else Result := n + 2; Writeln('Выход для n=',n,', F=',Result) end;
begin Writeln(F(3)) end.
Результат Вход с n=3 Вход с n=6 Выход для n=6, F=8 Вход с n=6 Выход для n=6, F=8 Вход с n=4 Вход с n=7 Выход для n=7, F=9 Вход с n=8 Выход для n=8, F=10 Вход с n=6 Выход для n=6, F=8 Выход для n=4, F=27 Выход для n=3, F=43 43
0,0(0 оценок)
Полный доступ
Позволит учиться лучше и быстрее. Неограниченный доступ к базе и ответам от экспертов и ai-bota
Оформи подписку