Итак, у меня есть этот код:
WRITELN( “input which member of series”)
READ(n)
p ← 2
prev1 ← 1
prev2 ← 1
WHILE p IS LESS THAN n DO
BEGIN
term ← prev1 + prev2
prev2 ← prev1
prev1 ← term
p ← p + 1
END
WRITELN (“term =”, term)
Может кто-нибудь помочь мне переписать код, чтобы он работал рекурсивно (на PHP или на Паскале).
РЕДАКТИРОВАТЬ
N = 4
Я использую PASCAL.Проблема в том, что нерекурсивный код возвращает 3, а рекурсивный код возвращает 2.
Это мой рекурсивный код:
program Fibfun;
VAR
n,prev1,prev2,term : Integer;
FUNCTION sw(p:integer):integer;Begin
if p < n then
Begin
term:= prev1 + prev2;
prev2:=prev1;
prev1:=term;
End
else
Begin
p:= 1 + sw(p);
End;
sw:=term;
End;
Begin
prev1:=1;
prev2:=1;
term:=1;
writeln('Input number: ');
readln(n);
writeln('term ', sw(2));
readln;
End.