求一个数的平方根
#include<stdio.h>
int main()
{
double sqrt1(double x);
double i, num;
printf("请输入数字:\n");
scanf("%lf", &num);
i = sqrt1(num);
printf("%lf的算术平方根为%lf.\n", num, i);
//printf("%lf的算术平方根为%lf.", num,sqrt(num));
}
double sqrt1(double x)
{
int i = 100;
double a;
a = x / 2;
while (i--)
{
a = (a + x / a) / 2;
}
return a;
}
a = x / 2;
while (i--)
{
a = (a + x / a) / 2;
}
return a;
帮忙解读一下这部分的代码,谢谢解答 参考地址:https://blog.csdn.net/carson2005/article/details/38613423
从这篇文章里面不难发现
计算一个数的平方根有一个类似逼近的方法
a = x / 2;以及 a = (a + x / a) / 2; 这部分是核心算法,不要问为什么,就是这么一个公式
主要你困惑的可能是
i=100 然后 while (i--)
这就是一个精度的问题
这是我的理解。 最牛的求平方根分之一代码。
4goodworld 发表于 2021-3-7 21:48
参考地址:https://blog.csdn.net/carson2005/article/details/38613423
从这篇文章里面不难发现
计算一 ...
谢谢回答 xieglt 发表于 2021-3-7 22:32
最牛的求平方根分之一代码。
谢谢
页:
[1]