Recursive Function with two Base Cases

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

MiauMiau
MiauMiau el 19 de Feb. de 2013
Unfortunately, that answer doesn't help
Azzi Abdelmalek
Azzi Abdelmalek el 19 de Feb. de 2013
You should try it.
MiauMiau
MiauMiau el 19 de Feb. de 2013
Editada: Azzi Abdelmalek el 19 de Feb. de 2013
although you have edited your answer now,
  1. the programms output is not according to the rules defined above. N = 4 for instance should give an output of 7.
  2. the program stays in an infinte loop.
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 Centro de ayuda y File Exchange.

Etiquetas

Preguntada:

el 19 de Feb. de 2013

Community Treasure Hunt

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

Start Hunting!

Translated by