yizhancs 发表于 2021-3-7 19:51:16

求一个数的平方根


#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;
帮忙解读一下这部分的代码,谢谢解答

4goodworld 发表于 2021-3-7 21:48:05

参考地址:https://blog.csdn.net/carson2005/article/details/38613423
从这篇文章里面不难发现
计算一个数的平方根有一个类似逼近的方法
a = x / 2;以及 a = (a + x / a) / 2; 这部分是核心算法,不要问为什么,就是这么一个公式
主要你困惑的可能是
i=100 然后 while (i--)
这就是一个精度的问题
这是我的理解。

xieglt 发表于 2021-3-7 22:32:26

最牛的求平方根分之一代码。

yizhancs 发表于 2021-3-8 19:12:28

4goodworld 发表于 2021-3-7 21:48
参考地址:https://blog.csdn.net/carson2005/article/details/38613423
从这篇文章里面不难发现
计算一 ...

谢谢回答

yizhancs 发表于 2021-3-8 19:12:59

xieglt 发表于 2021-3-7 22:32
最牛的求平方根分之一代码。

谢谢
页: [1]
查看完整版本: 求一个数的平方根