利用前面学习的循环和函数,来实现 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),或其他数字,看运行结果如何。