How do I code a function that's supposed to be an infinite pattern?
1 次查看(过去 30 天)
显示 更早的评论
I have a question as follows,
Let x = [x1 x2 x3 x4…..xn] and y = [y1 y2 y3 y4…….yn]. Write a MATLAB function to determine the following: (x1y2-x2y1+x2y3-x3y2+…..xny1-x1yn) Now assume x = [1 2 3 4 5] and y = [10 20 30 40 50]. Evaluate the above in this case.
However, I don't know how to code for a function that has "....yn" or "...xn",
What I have right now is literally this,
function [z] = Assignment1Question6b(x,y)
z = x(1)*y(2)-x(2)*y(1)+x(2)*y(3)-x(3)*y(2)+x(3)*y(4)-x(4)*y(3) + x(5)*y(1)-x(1)*y(5);
end
If anyone can point me in the right direction it would be a huge help, thank you!
2 个评论
Adam
2019-9-2
编辑:Adam
2019-9-2
You can use a for loop, over the size of the input array, since the formula is clearly defined in terms of e.g. k and k + 1 for a value k. Mind you, the leap from the ... to the final set of terms is a little suspicious since the last term apparently wraps round to work with index 1 when k + 1 would become great than n. It's still well defined, but not as clearly as it might be to be truly rigorous.
Remember that while the formula may be theoretically infinite the array passed in will always have a finite size, n, which you can get using, for example, numel( x )
回答(2 个)
Rajani Mishra
2019-9-9
As mentioned in the comment by Adam, Formula may be theoretically for infinite pattern but for arrays ‘x’ and ‘y’ size will be finite and can be found out using numel(x).
For mentioned pattern you can try below mentioned code:
z = 0;
n = numel(x);
for i=1:n-1
z = z + (x(i)*y(i+1) - x(i+1)*y(i));
end
z = z + x(n)*y(1) -x(1)*y(n);
0 个评论
另请参阅
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!