13. 用循环和函数 实现Sqrt(x)

利用前面学习的循环和函数,来实现 Sqrt(x)。并且与math.Sqrt(x)的结果做一下比较。
这个很有意思,所以,把中间不断带入的变化值都打印出来。
使用牛顿法来实现。牛顿法是同选择一个初始点z,然后重复这一过程求Sqrt(x)的近似值。



为了实现计算结果,只需要重复计算10次。

package main

import (
    "fmt"
    "math"
)

func Sqrt(x float64) float64 {
    var z float64 = 1.0
    for i:= 1; i < 10; i++{
        z = z - (z * z - x)/(2 * z)
        fmt.Println(z)
    }
    return z
}
func main() {
    fmt.Printf("My Sqrt(%d) is %g\n", 2, Sqrt(2))
    fmt.Printf("math.Sqrt(%d) is %g\n", 2, math.Sqrt(2))
}

运算结果如下

1.5
1.4166666666666667
1.4142156862745099
1.4142135623746899
1.4142135623730951
1.414213562373095
1.4142135623730951
1.414213562373095
1.4142135623730951
My Sqrt(2) is 1.4142135623730951
math.Sqrt(2) is 1.4142135623730951

试着修改Sqrt(2)为Sqrt(98),或其他数字,看运行结果如何。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容