C语言一元二次方程

输入一组数a,b,c
如果a的值足够小,接近于0,则输出不是二次方程的信息,并终止执行否则执行下一步
计算判别式△
计算p和q的值
p=-b/2*a
q=根号下△/2a
如果△的值足够小计算并输出两个相等的实根
如果为正计算并输出两个不等实根X1=p+q,X2=p-q
如果△的值为负计算并输出两个共轭复根 X1=p+qi X2=p-qi

#include<stdio.h>
#include<math.h>
#include<stdlib.h>
#define EPS 1e-6
int main()
{
    
    float a,b,c,disc,p,q;
    scanf("%f%f%f",&a,&b,&c);
    if(fabs(a)<=EPS)
    {
        printf("No\n");
        exit(0);
    }
    disc=b*b-4*a*c;
    if(fabs(disc<=EPS)
    {
        printf("x1=x2=%.2f\n",-b/(2*a));    
    }
    else
    {
        p=-b/(2*a);
        q=sqrt(fabs(disc))/(2*a);
        if(dis>1e-6)
        {
            printf("Two:x1=%.2f,x2=%.2f\n",p+q,p-q);
        }
        else
        {
            printf("复数根")
            printf("x1=%.2f+%.2fi\n",p,q);
            printf("x2=%.2f-%.2fi\n",p,q);
        }
    }
    return 0;
}

猜你喜欢

转载自blog.csdn.net/yang8627/article/details/83027324
今日推荐