标题:牛顿迭代法求根
只看楼主
lzxm160
Rank: 1
等 级:新手上路
帖 子:103
专家分:0
注 册:2006-12-26
 问题点数:0 回复次数:0 
牛顿迭代法求根
#include<stdio.h>
 #include<math.h>
    void main(){
    float f(float x);
    float f1(float x);
        float x2,x1=0.5;
        x2=x1-f(x1)/f1(x1);

        while(fabs(x2-x1)>1e-3)
        {
          x1=x2;
          x2=x1-f(x1)/f1(x1);

        }
        printf("%f",x2);
    }
    float f(float x)
    {
       float a=(((3*x+4)*x+5)*x)*x-6;
       return a;
    }
    float f1(float x)
    {
       float a=((12*x+12)*x+10)*x;
       return a;

    }
输出结果是表达式 3x^4+4x^3+5x^2+5x-6=0在0.5附近实根
调试结果是0.777557不知道对不对?
搜索更多相关主题的帖子: 牛顿 迭代法 
2007-12-04 22:32



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-190433-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.617455 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved