6-2 求解一元二次方程实根的函数 (10 point(s))
要求计算一元二次方程ax2+bx+c=0(a=0)的根。 主函数中给出3个浮点系数a、b、c,调用函数rootOfEquation()求解方程的实根。方程的根通过指针类型的参数x1、x2传回主函数,其中x1是值较大的根,x2是值较小的根。
- 若方程有两个相等的实根,函数返回1;
- 若方程有两个不等的实根,函数返回2;
- 若方程无实根,函数返回0。
函数接口定义:
int rootOfEquation(double a, double b, double c, double *x1, double *x2);
裁判测试程序样例:
#include<stdio.h>
#include<math.h>
int rootOfEquation(double a, double b, double c, double *x1, double *x2);
int main()
{ double a,b,c;
double x1,x2;
scanf("%lf %lf %lf",&a,&b,&c);
int flag;
flag=rootOfEquation(a,b,c,&x1,&x2);
if(flag==0)
printf("方程无实根");
else if(flag==1)
printf("方程有两个相等的实根 x1=x2=%.2f", x1);
else
printf("方程有两个不等的实根 x1=%.2f,x2=%.2f", x1, x2);
return 0;
}
/* 请在这里填写答案 */
输入样例:
1 3 2
结尾无空行
输出样例:
方程有两个不等的实根 x1=-1.00,x2=-2.00
结尾无空行
int rootOfEquation(double a, double b, double c, double *x1, double *x2)
{
double delta,t;
delta=b*b-4*a*c;
int f;
if (delta<0) f=0;
else if(delta>0) f=2;
else if(delta==0) f=1;
*x1=(-b+sqrt(delta))/(2*a);
*x2=(-b-sqrt(delta))/(2*a);
if(*x1<*x2){
t=*x1;
*x1=*x2;
*x2=t;
}
return f;
}