Function to compute product of all numbers from 1 to n

14 visualizaciones (últimos 30 días)
Dobs
Dobs el 22 de Nov. de 2021
Comentada: Dobs el 22 de Nov. de 2021
Hi,
I'm trying to solve the following problem: "Write a Matlab function that recursively computes the product of the integers from 1 to n". My code isnt' working though. This is what I got so far:
function r = integerproduct (n)
b = 1;
vector = 1:n;
for i = 1:length(vector)
while i <= 5
q = vector(i)*vector(i+b)
end
b=b+1;
r = q*vector(i+b)
end
end
I just used n = 5 as an example. If I understand the exercise correctly, the function is supposed to compute the following: 1*2*3*4*5 = 120.
It takes forever to run the code which seems a bit dodgy, surely it's not supposed to take that long? Does anyone have any hints as to what I should change so that 1) the function actually does what it's supposed to do and 2) the code runs as efficiently as possible?
Many thanks,
Dobs

Respuesta aceptada

Matt J
Matt J el 22 de Nov. de 2021
integerproduct(5)
ans = 120
function r = integerproduct (n)
if n==1, r=1; return; end
r=n*integerproduct(n-1);
end
  3 comentarios
Matt J
Matt J el 22 de Nov. de 2021
Editada: Matt J el 22 de Nov. de 2021
The function is already used inside the function itself?
Yes, that's what recursion is.
Dobs
Dobs el 22 de Nov. de 2021
Oh, I thought it meant that the function keeps going until n is reached (whatever n is). Thank you for clarifying!

Iniciar sesión para comentar.

Más respuestas (0)

Categorías

Más información sobre Matrix Indexing en Help Center y File Exchange.

Productos


Versión

R2021b

Community Treasure Hunt

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

Start Hunting!

Translated by