Информатика, опубликовано 2018-08-22 23:26:04 by Гость

Дан рекурсивный алгоритм: 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     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

Не нашли ответа?
Если вы не нашли ответа на свой вопрос, или сомневаетесь в его правильности, то можете воспользоваться формой ниже и уточнить решение. Или воспользуйтесь формой поиска и найдите похожие ответы по предмету Информатика.

Форма вопроса доступна на полной версии этой страницы.