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日

悬赏问题

  • ¥15 微信小程序协议怎么写
  • ¥15 c语言怎么用printf(“\b \b”)与getch()实现黑框里写入与删除?
  • ¥20 怎么用dlib库的算法识别小麦病虫害
  • ¥15 华为ensp模拟器中S5700交换机在配置过程中老是反复重启
  • ¥15 java写代码遇到问题,求帮助
  • ¥15 uniapp uview http 如何实现统一的请求异常信息提示?
  • ¥15 有了解d3和topogram.js库的吗?有偿请教
  • ¥100 任意维数的K均值聚类
  • ¥15 stamps做sbas-insar,时序沉降图怎么画
  • ¥15 买了个传感器,根据商家发的代码和步骤使用但是代码报错了不会改,有没有人可以看看