making an Xn sequence
13 ビュー (過去 30 日間)
古いコメントを表示
I'm trying to code the function Xn=111-(1130/Xn-1)+3000/(Xn-1*Xn-2)
I don't know how to make this sequence in MatLab
I think I can figure out the rest of the problem, I'm just not sure how to do this part particularly
2 件のコメント
Walter Roberson
2020 年 9 月 11 日
If n is at least 3 then
would be written X(n-2) and
would be written X(n-1) and
would be written X(n)
回答 (1 件)
BOB MATHEW SYJI
2020 年 9 月 13 日
Hope this helps. x1 and x2 are the 1st and 2nd terms of the sequence respectively. n is the nth term you want.
x1=%the first number of the sequence
x2=%the second number of the sequence
n=%the nth element you want
x=[x1 x2];
for i=3:n
x(i)=111-(1130/x(i-1))+(3000/(x(i-1)*x(i-2)));
end
disp(x(n));
2 件のコメント
John D'Errico
2020 年 9 月 13 日
編集済み: John D'Errico
2020 年 9 月 13 日
I would suggest you learn why and how to preallocate vectors when they will be grown. Else your code will be exceedingly slow, leaving you to soon post an anguished question of your own at some time - "Why is this code so slow?"
In this case, the code you wrote will create a vector of length n, but your code grows that vector in length one step at a time, forcing MATLAB to reallocate memory at every iteration. It also forces MATLAB to copy the entire vector over at every iteration. If n is at all large, this creates code that will run in O(n^2) time. It is an unnecesarily inefficient coding style, avoidable by a simple line at the beginning like
x = zeros(1,n);
参考
カテゴリ
Help Center および File Exchange で File Operations についてさらに検索
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!