C语言 一元二次方程求根,带注释(详细)

/*包含stdio.h头文件,以便于使用输入函数scanf和输出函数printf*/

#include<stdio.h>

/*包含头文件math.h,以便于使用开平方根函数sqrt, 以及绝对值函数fabs*/

#include<math.h>

int main()

{

/*定义一元二次方程的系数 ax^2 + bx +c =0*/

float a,b,c;

/*定义变量deta = b*b - 4ac*/

float delta;

/*定义两个根*/

float u, v;

/*从控制台获取输入*/

scanf("%f %f %f", &a,&b,&c);

/*处理第一种情况:系数都为0*.

由于浮点数,判断其等于0的表达式为其绝对值小于等于10^{-5},

即采用绝对值函数fabs*/

if( fabs(a)<=1e-5 && fabs(b) <=1e-5 && fabs(c)<=1e-5)

{

printf("Zero Equation\n");

/*return 目的是不执行其他代码*/

return 0;

}

/*由于a=0,b=0,c=0的情形已经被处理了(被返回了),

那么接下来的情况是a,b,c不都是0*/

/*情况1: a=0,b=0, c不等于0*/

if( fabs(a)<=1e-5 && fabs(b) <=1e-5 && fabs(c)>1e-5)

{

printf("Not An Equation\n");

/*return 目的是不执行其他代码*/

return 0;

}

/*经过上述两种处理可知,ab不都是0,否则被上述情况处理并返回了*/

/*情况2:a=0, b不等于0(必然)*/

if(fabs(a)<=1e-5) { printf("%.2f\n", -c/b); return 0;}

/* a不等于0,那么就有可能是实根或者虚根

*为此先计算delta = b*b-4ac*/

delta = b*b -4*a*c;

/*情况3: delta ==0,就只有一个根*/

if(fabs(delta)<1e-5) { printf("%.2f\n", -b/(2*a)); return 0;}

/*由于情况delta==0必处理并返回了,那么delta 肯定不等于0*/

/*情况4: delta >0*/

if( delta >0)

{

/*两个根分别为*/

u = (-b + sqrt(delta))/(2*a);

v = (-b - sqrt(delta))/(2*a);

printf("%.2f\n", u);

printf("%.2f\n",v);

return 0;

}

/*经过上述处理,只剩下delta<0*

*即只有两个虚数根*/

/*情况5: b=0, 方程只有虚根*/

if(fabs(b)<=1e-5)

{

printf("0.00+%.2fi\n", sqrt(-delta)/(2*a));

printf("0.00-%.2fi\n", sqrt(-delta)/(2*a));

return 0;

}

/*情况 6: b不等于0, 复数根*/

printf("%.2f+%.2fi\n", -b/(2*a), sqrt(-delta)/(2*a));

printf("%.2f-%.2fi\n", -b/(2*a), sqrt(-delta)/(2*a));

return 0;

}

  • 18
    点赞
  • 46
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

霖䨎

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值