Function to compute product of all numbers from 1 to n
6 次查看(过去 30 天)
显示 更早的评论
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
0 个评论
采纳的回答
Matt J
2021-11-22
integerproduct(5)
function r = integerproduct (n)
if n==1, r=1; return; end
r=n*integerproduct(n-1);
end
3 个评论
更多回答(0 个)
另请参阅
类别
在 Help Center 和 File Exchange 中查找有关 Loops and Conditional Statements 的更多信息
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!