• 一元三次方程求解(折半查找)


    Description
    有形如:ax3+bx2+cx+d=0  这种一个一元三次方程。给出该方程中各项的系数(a,b,c,d  均为实数),并约定该方程存在三个不同实根(根的范围在-100至100之间),且根与根之差的绝对值>=1。请你求出这个方程的三个实根。

    Input
    仅仅有一行,包含4个实数a,b,c,d,中间用一个或多个空格隔开。

    Output
    仅仅有一行,包含三个整数,为由小到大排列的三个实根(根与根之间留有空格),并精确到小数点后2位。

    Sample Input
    1   -5   -4   20

    Sample Output
    -2.00 2.00 5.00

    解题思路:

    若f(a) * f (b)  < 0,则在(a,b)区间内至少有一个根。题目规定根的范围在-100至100之间,且根与根之差的绝对值>=1,所以仅仅需对[-100,-99),[-99,-98)...[99,100)的全部区间遍历一遍,然后用折半查找根就可以。

    AC代码:

    #include<stdio.h>
    double a, b, c, d;
    double Func(double x)
    {
        double result;
        result = a * x * x * x + b * x * x + c * x + d;  // 计算f(x)的值
        return result;
    }
    int main()
    {
        double x;
        scanf("%lf%lf%lf%lf", &a, &b, &c, &d);
        for(int i = -100; i <= 100; i++)
        {
            if(Func(i * 1.0) * Func((i + 1) * 1.0) < 0)  // 推断该区间中是否有根
            {
                double low = i * 1.0, high = (i + 1) * 1.0, mid;
                while(high - low > 1e-8)   
                {
                    mid = (high + low) / 2;
                    if(Func(mid) * Func(high) <= 0)   // 进行折半查找
                        low = mid;
                    else
                        high = mid;
                }
                printf("%.2lf ", mid);
            }
            if(Func(i * 1.0) == 0)        // 另一种情况就是根就在区间边界上
                printf("%.2lf ",i * 1.0);
        }
        return 0;
    }
    



  • 相关阅读:
    Turtlebot-导航
    Turtlebot-创建地图-Gmapping-Kinect
    Gflags
    Linux Driver 入门
    Linux Kernel 入门
    Linux Driver 入门
    Linux Driver 入门
    Linux Driver 入门
    Win10 复制文件路径
    vs2010 nuget 基础连接已经关闭:发送时发生错误
  • 原文地址:https://www.cnblogs.com/mfrbuaa/p/4184743.html
Copyright © 2020-2023  润新知