Augenstern... 2022-02-16 20:11 采纳率: 75%
浏览 33
已结题

pta7-18二分法求多项式单根总是在测试点二显示运行超时,改了几次都没改过,求各位看看错在哪。

img

img

#include <stdio.h>
float a3,a2,a1,a0;
float f(float x);
int main()
{
    float a,b;
    scanf("%f %f %f %f",&a3,&a2,&a1,&a0);
    scanf("\n%f %f",&a,&b);
    float left,right;
    left=a;
    right=b;
    float mid=0;
    while(right-left>=0.0001&&f(left)*f(right)<=0){
        if(f(left)==0){
            printf("%.2f",left);
            return 0;
        }else if(f(right)==0){
            printf("%.2f",right);
            return 0;
        }
        mid=(left+right)/2;
        if(f(mid)*f(left)>0){
            left=mid;
        }else if(f(mid)*f(left)<0){
            right=mid;
        }
    } 
    printf("%.2f",mid);
    return 0;
}
float f(float x){
    float end;
    end=a3*x*x*x+a2*x*x+a1*x+a0;
    return end;
}

  • 写回答

2条回答 默认 最新

  • 谛凌 2022-02-16 20:36
    关注

    试试这样:

    #include <stdio.h>
    float a3,a2,a1,a0;
    float f(float x);
    int main()
    {
        float a,b;
        scanf("%f %f %f %f",&a3,&a2,&a1,&a0);
        scanf("\n%f %f",&a,&b);
        float left,right;
        left=a;
        right=b;
        float mid=0;
        while(right-left>=0.0001&&f(left)*f(right)<=0){
            if(f(left)==0){
                printf("%.2f",left);
                return 0;
            }else if(f(right)==0){
                printf("%.2f",right);
                return 0;
            }
            mid=(left+right)/2;
            if(f(mid)*f(left)>0){
                left=mid;
            }else if(f(mid)*f(left)<0){
                right=mid;
            }else{
                printf("%.2f",mid);
                return 0;
            }
        } 
        printf("%.2f",mid);
        return 0;
    }
    float f(float x){
        float end;
        end=a3*x*x*x+a2*x*x+a1*x+a0;
        return end;
    }
     
    

    img

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 已结题 (查看结题原因) 2月17日
  • 已采纳回答 2月16日
  • 创建了问题 2月16日

悬赏问题

  • ¥30 帮我写一段可以读取LD2450数据并计算距离的Arduino代码
  • ¥15 C#调用python代码(python带有库)
  • ¥15 矩阵加法的规则是两个矩阵中对应位置的数的绝对值进行加和
  • ¥15 活动选择题。最多可以参加几个项目?
  • ¥15 飞机曲面部件如机翼,壁板等具体的孔位模型
  • ¥15 vs2019中数据导出问题
  • ¥20 云服务Linux系统TCP-MSS值修改?
  • ¥20 关于#单片机#的问题:项目:使用模拟iic与ov2640通讯环境:F407问题:读取的ID号总是0xff,自己调了调发现在读从机数据时,SDA线上并未有信号变化(语言-c语言)
  • ¥20 怎么在stm32门禁成品上增加查询记录功能
  • ¥15 Source insight编写代码后使用CCS5.2版本import之后,代码跳到注释行里面