YumeNoTsuduki 2021-10-22 11:01 采纳率: 100%
浏览 241
已结题

c语言求一元二次方程

img


#include<stdio.h>
#include<math.h>
int main(void)
{
    double a,b,c,d,x1,x2,x;
    scanf("%lf %lf %lf",&a,&b,&c);
    d=b*b-4*a*c;
    if(a==0&&b==0&&c==0)
    printf("Zero Equation");
    else if(a==0&&b==0&&c!=0)
    printf("Not An Equation");
    else if(d>0)
    {
        x1=(-b+sqrt(d))/(2*a);
        x2=(-b-sqrt(d))/(2*a);
        if(x1>x2)
        printf("%.2lf\n%.2lf",x1,x2);
        else
         printf("%.2lf\n%.2lf",x2,x1);
    }
    else if(d==0)
    {
    x=b/(2*a);
printf("%.2lf",x);
}
else if(d<0)
{
        x1=(-b+sqrt(d))/(2*a);
        x2=(-b-sqrt(d))/(2*a);
        printf("0.0+%.2lfi\n0.0-%.2lfi",x1,x2);
}
return 0;
}

img


剩下的还是不会

  • 写回答

1条回答 默认 最新

  • 地球屋里老师 2021-10-22 11:48
    关注
    
     
    #include<stdio.h>
    #include<math.h>
    int main(void)
    {
        double a,b,c,d,x1,x2;
        double eps=1.0e-15;
        scanf("%lf %lf %lf",&a,&b,&c);
        d = fmax(fabs(a),fabs(b));
        d = fmax(d,fabs(c));
        if(d<eps) {
          printf("Zero Equation\n");
          return 0;
        }
        a = a / d;
        b = b / d;
        c = c / d; //归一化
        if(fabs(a)<eps&&fabs(b)<eps) {
          printf("Not An Equation\n");
          return 0;
        }
        d = b*b - 4*a*c;
        if(d>eps) {
          x1=(-b+sqrt(d))/(2*a);
          x2=(-b-sqrt(d))/(2*a);
          if(x1>x2)
            printf("%.2lf\n%.2lf",x1,x2);
          else
            printf("%.2lf\n%.2lf",x2,x1); //两个实根
        }
        else if(d>-eps) {
          x1 = -b / (2*a);
          printf("%.2lf",x1); //一个实根
        }
        else {
          d = fabs(sqrt(-d) / (2*a));
          b = -b / (2*a);
          printf("%.2lf+%.2lfi\n",b,d);
          printf("%.2lf-%.2lfi\n",b,d); //共轭复根
        }
        return 0;
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 10月31日
  • 已采纳回答 10月23日
  • 创建了问题 10月22日

悬赏问题

  • ¥20 关于#硬件工程#的问题,请各位专家解答!
  • ¥15 关于#matlab#的问题:期望的系统闭环传递函数为G(s)=wn^2/s^2+2¢wn+wn^2阻尼系数¢=0.707,使系统具有较小的超调量
  • ¥15 FLUENT如何实现在堆积颗粒的上表面加载高斯热源
  • ¥30 截图中的mathematics程序转换成matlab
  • ¥15 动力学代码报错,维度不匹配
  • ¥15 Power query添加列问题
  • ¥50 Kubernetes&Fission&Eleasticsearch
  • ¥15 報錯:Person is not mapped,如何解決?
  • ¥15 c++头文件不能识别CDialog
  • ¥15 Excel发现不可读取的内容