/*
求解一元二次方程
*/
#include <stdio.h>
#include <string.h>
#include <math.h>
int solveEquation(const double a,const double b,const double c)
{
double x1,x2;
double delta = b*b - 4*a*c;
if(a == 0){
printf("a = 0 is not quadratic equation with one unknown!\n");
return 0;
}
if(delta > 0){
//两个解
x1 = (-b + sqrt(delta)) / (2*a);
x2 = (-b - sqrt(delta)) / (2*a);
printf("两个解:\nx1 =\t%lf\nx2 =\t%lf\n",x1,x2);
}else if(delta == 0){
//唯一解
x1 = (-b) / (2*a);
printf("唯一解:x1 = x2 = %lf\n",x1);
}else{
//无解
printf("无解!\n");
}
}
int main(int argc, char* argv[])
{
double a, b, c;
int key = 0,count = 1;;
a = b = c = 0;
while(count)
{
printf("Please input a, b, c and a != 0:");
scanf("%lf%lf%lf",&a,&b,&c);
solveEquation(a,b,c);
//继续或者循环控制
printf("continue intput (y or n)?\n");
key = getch();
if (key == 'n' || key == 'N'){
count = 0;
}
}
return 0;
}
求解一元二次方程
最新推荐文章于 2022-09-10 17:16:38 发布
本文介绍了一种使用C语言实现的一元二次方程求解程序。该程序能够根据输入的系数a、b和c,判断方程的根的情况,并给出具体的解。通过循环输入的方式,用户可以多次尝试不同的方程组。
927

被折叠的 条评论
为什么被折叠?



