// 所有虚数,实数都只保留 5 位小数
#include <iostream>
#include <cstdio>
#include <math.h>
using namespace std;
double EPS = 0.00001; // 用来控制精度
int main(void)
{
double a, b, c;
scanf("%lf %lf %lf", &a, &b, &c);
double delta = 4 * a * c; // 判别式
double x1, x2;
if (b*b == delta){
// 有相同的两个 根
x2 = x1 = (-b + sqrt(b*b - delta)) / (2 * a);
printf("x1=x2=%.5f", x1, x1);
} else if (b*b > delta) {
// 两个不相同的 根
x1 = (-b + sqrt(b*b - delta)) / (2 * a);
x2 = (-b - sqrt(b*b - delta)) / (2 * a);
printf("x1=%.5f;x2=%.5f", x1, x2);
} else { // 虚数根
double x1_im, x2_im;
x1 = x2 = -b / (2*a);
// 因为输出的时候只保留5位小数,所以 0.000001, -0.00000001 都被看做 零
if (x1 > -EPS && x1 < EPS){
x1 = 0;
x2 = 0;
}
x1_im = x2_im = sqrt(4*a*c - b*b) / (2*a);
printf("x1=%.5f+%.5fi;x2=%.5f-%.5fi", x1, x1_im, x2, x2_im);
}
}
求一元二次方程的根(包括虚数根)
最后编辑于 :
©著作权归作者所有,转载或内容合作请联系作者
- 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
- 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
- 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
推荐阅读更多精彩内容
- 最近工作中需要用到图片的自动化处理,于是了解了一下PIL程序库。 什么是PIL PIL(Python Imagin...