根号快速计算牛顿迭代法

前言

你是否计算 36\sqrt{36}36 时,立马得出 666 这个答案。

但是,如果我问你,17\sqrt{17}17 等于多少,聪明的你,拿出计算机。额。

如何自己算

用代码可以出来的。

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
int main()
{
   cout<<sqrt(17);
}

但是自己咋算,我们可使用牛顿迭代法。

明确根号转化

我们知道,根号就像解方程。

也就是 x2=nx^2= \sqrt{n}x2=n ,求出 xxx,也就是 xxx 是 nnn 的平方根。

那么我们可以将平方根理解成这个东西。

我们可以把 nnn 视为个长方形。

开始算了,与 171717 最接近平方根而且易算的是 161616,那我们就设一条边为 444,那么另一条边就是。

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
int main()
{
   printf("%.2lf",17/4);
}

算出来是 4.254.254.25,画出来图就是这样。

这长的也不想正方形,平均一下,(4+4.25)÷2(4+4.25)\div2(4+4.25)÷2。

算出来等于 4.1254.1254.125。

要是除 222 除不进就保留小数。

再此除看看那条边等于多少,大约 4.1214.1214.121。

我们再平均一次 (4.125+4.121)÷2(4.125+4.121)\div2(4.125+4.121)÷2,等于多少,算出结果!

是 4.1234.1234.123。

对照计算机。

一样,如果更大位,小数位数可以算大。

这就是微积分中的牛顿迭代法。

代码

cpp 复制代码
#include <iostream>
#include <iomanip>
using namespace std;
double sqrt(double n) {
    double x = 1;
    for (int i = 0; i < 100; i++) {
        x = (x + n / x) / 2;
    }
    return x;
}
int main() {
    double num;
    cin >> num;
    cout << fixed << setprecision(10);
    cout << sqrt(num) << endl;
    return 0;
}
相关推荐
jiayong231 小时前
第 41 课:任务详情抽屉里的快速筛选联动
开发语言·前端·javascript·vue.js·学习
菜鸟丁小真1 小时前
LeetCode hot100-79.单词搜索
数据结构·算法·leetcode·深度优先·知识总结
WL_Aurora2 小时前
排序算法(二)
java·算法·排序算法
xiaoshuaishuai82 小时前
【无标题】
开发语言·windows·c#
Tisfy2 小时前
LeetCode 2833.距离原点最远的点:计数
算法·leetcode·字符串·题解·模拟·计数
小小de风呀2 小时前
de风——【从零开始学C++】(二):类和对象入门(一)
开发语言·c++
浅念-2 小时前
LeetCode 模拟算法:用「还原过程」搞定编程题的入门钥匙
开发语言·c++·学习·算法·leetcode·职场和发展·模拟
t-think2 小时前
操作符详解-C语言(下)
c语言·算法
澈2072 小时前
C++面向对象编程:从封装到实战
开发语言·c++