牛顿迭代法求方程的根

转自:https://blog.csdn.net/qq_31029351/article/details/53311285
牛顿法求最优解,本质上就是求f(x)=0的过程,求某个点的方根,本质上是求x^n-m=0的过程,如求f(x)=x^2,当f(x)=3,求x的最优解,就是求x^2-3=0的x的解。
牛顿迭代法求方程的根。
这里写图片描述

下面解决ax^3 + bx^2 + cx +b =0;一个根在1附近,约束条件|x - x0| <= 1e-5;
下面步骤讲解。
(1)选取迭代初值。x = 1.5
(2)f = ax0^3 + bx0^2 +cx0 +d fd = 3ax0^2 + 2bx0 + c
(3)增量h = f/fd
(4)循环条件fabs(x - x0) >=1e-5

下面给出具体的程序。

include <stdio.h>
include <math.h>

int main()
{
     flaot solution(float a,flaot b,float c,float d);
     float a;
     float b;
     float c;
     float d;
     scanf("%f%f%f%f",&a,&b,&c,&d);
     printf("the soulution is %f\n",solution(a,b,c,d);

     return 0;
}
float solution(float a, float b, float c,float d)
{
    float x = 1.5;
    float x0;
    float f;
    float fd;

    while(fabs(x - x0)>= 1e-5)
    {
        x0 = x;
        f = a * x0 * x0 * x0  + b * x0 * x0 +c * x0 + d;
        fd = 3 * a * x0 * x0 + 2 * b * x0 +c;
        x = x0 - f / fd;  
    }

    return x;
}
  • 4
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值