#include <iostream>
#include <math.h>
using namespace std;

double Grial(int x)
{
	double result = 1;
	double num = x;
	do{
			result = num;
			num = result/2.0+x/2.0/result;
		}while(fabs(num-result)>0.00001);
	return result;
}
//牛顿迭代公式x(n+1)=x(n)-f(x(n))/f'(x(n))
//求N的平方根就是求f(x)=N-x^2=0的解
//x1=x2;
//然后就是x2 = x1-(N-x1^2)/(-2x1)=x1/2.0+N/2.0/x1
int main()
{
	cout<<Grial(3)<<endl;
	return 0;
}

相关文章:

  • 2021-11-29
  • 2022-12-23
  • 2022-01-03
  • 2022-12-23
  • 2021-05-31
  • 2021-08-18
  • 2021-11-24
  • 2021-11-27
猜你喜欢
  • 2022-03-06
  • 2022-01-11
  • 2022-12-23
  • 2021-09-20
  • 2022-12-23
  • 2021-08-16
  • 2022-12-23
相关资源
相似解决方案