求一元二次方程ax2+bx+c=0的解。a,b,c为任意实数。
#include<stdio.h>#include<math.h>intmain(){doublea,b,c,x1,x2,p,q,f,g,m,n,i;scanf("%lf...
#include <stdio.h>
#include <math.h>
int main()
{
double a,b,c,x1,x2,p,q,f,g,m,n,i;
scanf("%lf%lf%lf",&a,&b,&c);
p=-b/(2.0*a);
q=sqrt(b*b-4*a*c)/2*a*c;
if(b*b-4*a*c>=0)
{
f=p+q;
g=p-q;
}
if(f>g)x1=f,x2=g;
else x1=g,x2=f;
if(b*b-4*a*c<0)
{
m=-b/2*a;
n=sqrt(4*a*c-b*b)/a*2;
x1=m+n*i;
x2=m-n*i;
}
printf("%.2f %.2f",x1,x2);
return 0;
}
错在哪 展开
#include <math.h>
int main()
{
double a,b,c,x1,x2,p,q,f,g,m,n,i;
scanf("%lf%lf%lf",&a,&b,&c);
p=-b/(2.0*a);
q=sqrt(b*b-4*a*c)/2*a*c;
if(b*b-4*a*c>=0)
{
f=p+q;
g=p-q;
}
if(f>g)x1=f,x2=g;
else x1=g,x2=f;
if(b*b-4*a*c<0)
{
m=-b/2*a;
n=sqrt(4*a*c-b*b)/a*2;
x1=m+n*i;
x2=m-n*i;
}
printf("%.2f %.2f",x1,x2);
return 0;
}
错在哪 展开
2个回答
展开全部
#include <stdio.h>
#include <math.h>
int main()
{
double a,b,c,x1,x2,p,q,f,g,m,n,i;
scanf("%lf%lf%lf",&a,&b,&c);
p=-b/(2.0*a);
q=sqrt(b*b-4*a*c)/(2*a);
if(b*b-4*a*c>=0)
{
f=p+q;
g=p-q;
}
if(f>g)x1=f,x2=g;
else x1=g,x2=f;
if(b*b-4*a*c>=0)
printf("x1=%lf, x2=%lf",x1,x2);
else
{
m=-b/(2*a);
n=sqrt(4*a*c-b*b)/(a*2);
printf("x1=%lf+%lf i, x2=%lf-%lf i",m,n,m,n);
}
return 0;
}
我只是把你代码中的关键错误改了,其实你的代码很不简洁,要加强代码精简,提高代码效率!
#include <math.h>
int main()
{
double a,b,c,x1,x2,p,q,f,g,m,n,i;
scanf("%lf%lf%lf",&a,&b,&c);
p=-b/(2.0*a);
q=sqrt(b*b-4*a*c)/(2*a);
if(b*b-4*a*c>=0)
{
f=p+q;
g=p-q;
}
if(f>g)x1=f,x2=g;
else x1=g,x2=f;
if(b*b-4*a*c>=0)
printf("x1=%lf, x2=%lf",x1,x2);
else
{
m=-b/(2*a);
n=sqrt(4*a*c-b*b)/(a*2);
printf("x1=%lf+%lf i, x2=%lf-%lf i",m,n,m,n);
}
return 0;
}
我只是把你代码中的关键错误改了,其实你的代码很不简洁,要加强代码精简,提高代码效率!
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询