码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 牛顿迭代法


    牛顿迭代法

    介绍

    牛顿法是牛顿在17世纪提出的一种在实数域和复数域上近似求解方程的方法。牛顿法常用来求解非线程方程近似根。牛顿法通过迭代的方式去逼近方程的解。

    原理

    如图所示,牛顿法通过迭代的方式去逼近方程的解,通过利用初始点的斜率去逼近方程的根。而点的斜率公式又可以通过方程的导数得出。我们在(x0,f(x0))斜率做斜线f'(x0),求出与X轴的交点x1,重复以上过程直到f(xn)无限接近于0即可。

    请添加图片描述

    ​

    ​ 设有一非线性方程f(x),为了求该方程的根,可以设一个初始值x0,设该点的斜率方程为f'(x0),那么f'(x0)和X轴有交点x1。那么,可以得出x1=x0-f(x0)/f'(x0)。求出x1后就继续求x2,x3。直至f(xn)接近于0,当然也可以用两个点xn和xn-1之间的差接近于0来代表迭代的结束;于是有以下公式:
    x n + 1 = x n − f ( x n ) f ′ ( x n ) x_{n+1}=x_{n}-\frac{f\left(x_{n}\right)}{f^{\prime}\left(x_{n}\right)} xn+1​=xn​−f′(xn​)f(xn​)​

    例题

    leetcode第69题.x的平方根

    69. x 的平方根 - 力扣(LeetCode)

    如题:

    请添加图片描述

    解题思路:

    x 的平方根 - x 的平方根 - 力扣(LeetCode)

    注意题目不允许使用任何内置指数函数和算符,例如 pow(x, 0.5) 或者 x ** 0.5 ,去求要求的数的平方根

    在解题中设待求平方根的数为C,那么求平方根的公式为
    f ( x ) = x 2 − C f(x)=x^{2}-C f(x)=x2−C
    然后根据上面的牛顿迭代公式:
    x n + 1 = x n − f ( x n ) f ′ ( x n ) x_{n+1}=x_{n}-\frac{f\left(x_{n}\right)}{f^{\prime}\left(x_{n}\right)} xn+1​=xn​−f′(xn​)f(xn​)​
    可以得出:
    x i + 1 = 1 2 ( x i + C x i ) x_{i+1}=\frac{1}{2}\left(x_{i}+\frac{C}{x_{i}}\right) xi+1​=21​(xi​+xi​C​)
    然后题目设x0=C为初始值
    x 0 = C x_{0}=C x0​=C
    通过迭代去逼近方程中的其中的一个解,即是C的平方根
    x = C x=\sqrt{C} x=C ​

  • 相关阅读:
    安全漏洞-linux漏洞修复命令
    Java开发面试常见问题总结
    18. 深度学习 - 从零理解神经网络
    Git 教程详解
    猜数字,玩游戏(随机生成1到100之间的数字,进行猜数字游戏)
    Instant-NGP论文笔记
    小程序如何搭建在服务器上
    Java中树形(层次)结构数据库MySql设计方案(类似目录)
    P3371 【模板】单源最短路径(弱化版)
    DC-6靶场下载及渗透实战详细过程(DC靶场系列)
  • 原文地址:https://blog.csdn.net/qq_43203949/article/details/125631040
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号