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

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日

悬赏问题

  • ¥100 X轴为分离变量(因子变量),如何控制X轴每个分类变量的长度。
  • ¥30 求给定范围的全体素数p的(p-2)的连乘积
  • ¥15 VFP如何使用阿里TTS实现文字转语音?
  • ¥100 需要跳转番茄畅听app的adb命令
  • ¥50 寻找一位有逆向游戏盾sdk 应用程序经验的技术
  • ¥15 请问有用MZmine处理 “Waters SYNAPT G2-Si QTOF质谱仪在MSE模式下采集的非靶向数据” 的分析教程吗
  • ¥50 opencv4nodejs 如何安装
  • ¥15 adb push异常 adb: error: 1409-byte write failed: Invalid argument
  • ¥15 nginx反向代理获取ip,java获取真实ip
  • ¥15 eda:门禁系统设计