can you solve this problem

I solved this problem but the file didn't run, the codes in the editor are:
function [s,ea,i]=SqRoot(a,eps,maxit)
i = 0;
s = a/2;
ea = 100;
while(1)
sold = s;
s= (s+a/s)/2;
i = i+1;
if s ~= 0, ea=abs((s - sold)/s)*100; end
if ea <= eps | i>= maxit, break, end
end

5 个评论

You need to post the actual error message. As it stands, I see several errors in your code:
  1. if ea eps | i= maxit : this is not Matlab syntax, there's no comparison of the values
  2. Your function doesn't terminate with an end block
  3. You are using , instead of ; to terminate lines
Additionally, there's no reason to use a while loop here when you can use a for loop instead.
You're using | in the if instead of | | (two bars).
How did you call it? What are a, eps, and maxit. By the way, eps is a built in variable so you should not use that as the name of your own variable.
Have you tried stepping through it with the debugger? That's what everybody does in cases like this - so should you.
it works, but do we have to create input for this? did you see the attached photo? the question says:
the "divide and average" method, an old-time method for approximating the square root of any positive number a, can be formulated as x=(x+a/2)/2. write a well-structured function to implement this alogrithm.
I already wrote the right answer from my instructor for this problem. why did you gave the variable "a" a value of 50!. can you fix it if you think the codes must be slightly different?
‘Did you see the attached photo?’
No, because no photo was attached.
a_arg = rand();
eps_arg = randn() / 10^8;
maxit_arg = randi([10,500]);
[s_ans, ea_ans, i_ans] = Student(a_arg, eps_arg, maxit_arg)

请先登录,再进行评论。

回答(1 个)

Your code runs for me, and produces the correct result:
a = 50; % Argument
maxit = 100; % Argument
i = 0;
s = a/2;
ea = 100;
while(1)
sold = s;
s= (s+a/s)/2;
i = i+1;
if s ~= 0, ea=abs((s - sold)/s)*100; end
if ea <= eps || i>= maxit, break, end
end
What problems are you having with it?

类别

帮助中心File Exchange 中查找有关 Networks 的更多信息

Community Treasure Hunt

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

Start Hunting!

Translated by