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!

Risposte (1)

Azzi Abdelmalek
Azzi Abdelmalek il 19 Feb 2013
Modificato: Azzi Abdelmalek il 19 Feb 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 Commenti

Unfortunately, that answer doesn't help
You should try it.
MiauMiau
MiauMiau il 19 Feb 2013
Modificato: Azzi Abdelmalek il 19 Feb 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.
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)
now it works, thanks!

Accedi per commentare.

Categorie

Scopri di più su Waveform Design and Signal Synthesis in Centro assistenza e File Exchange

Tag

Richiesto:

il 19 Feb 2013

Community Treasure Hunt

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

Start Hunting!

Translated by