Recursive Function with two Base Cases

10 visualizaciones (últimos 30 días)
MiauMiau
MiauMiau el 19 de Feb. de 2013
Hi
Let the Lucas Numbers be defined as follows:
1 for n = 1
3 for n = 2
L_n = L_(n-1) + L_(n-2) for n >= 3
Why doesn't my code work? Here is the code:
function a = lucas(N)
N = input('please enter an integer:')
if N == 1
a = 1;
elseif N == 2
a = 3;
elseif
a = lucas(N-1)+ lucas(N-2)
end
disp(N)
end
thanks!

Respuestas (1)

Azzi Abdelmalek
Azzi Abdelmalek el 19 de Feb. de 2013
Editada: Azzi Abdelmalek el 19 de Feb. de 2013
It's not elseif use else
Also you are using a function with input argument N, why in your function you added:
N = input('please enter an integer:')
What you should do is:
function a = lucas(N)
if N == 1
a = 1;
elseif N == 2
a = 3;
else
a = lucas(N-1)+ lucas(N-2)
end
disp(N)
And in windows command
N = input('please enter an integer:')
a=lucas(N)
  5 comentarios
Azzi Abdelmalek
Azzi Abdelmalek el 19 de Feb. de 2013
Editada: Azzi Abdelmalek el 19 de Feb. de 2013
I forget to remove , input from your function. It gives 7 for N=4
save this function
function a = lucas(N)
if N == 1
a = 1;
elseif N == 2
a = 3;
else
a = lucas(N-1)+ lucas(N-2)
end
disp(N)
in windows command type
lucas(4)
MiauMiau
MiauMiau el 19 de Feb. de 2013
now it works, thanks!

Iniciar sesión para comentar.

Categorías

Más información sobre Waveform Design and Signal Synthesis en Help Center y File Exchange.

Etiquetas

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by