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!

답변 (1개)

Azzi Abdelmalek
Azzi Abdelmalek 2013년 2월 19일
편집: Azzi Abdelmalek 2013년 2월 19일

0 개 추천

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

MiauMiau
MiauMiau 2013년 2월 19일
Unfortunately, that answer doesn't help
Azzi Abdelmalek
Azzi Abdelmalek 2013년 2월 19일
You should try it.
MiauMiau
MiauMiau 2013년 2월 19일
편집: Azzi Abdelmalek 2013년 2월 19일
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 2013년 2월 19일
편집: Azzi Abdelmalek 2013년 2월 19일
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 2013년 2월 19일
now it works, thanks!

댓글을 달려면 로그인하십시오.

카테고리

도움말 센터File Exchange에서 Waveform Design and Signal Synthesis에 대해 자세히 알아보기

태그

질문:

2013년 2월 19일

Community Treasure Hunt

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

Start Hunting!

Translated by