#include <stdio.h>
#include <math.h>
void quadratic_equation_roots(float a, float b, float c) {
float discriminant = (b * b) - (4 * a * c);
float root1, root2;
if (discriminant > 0) {
root1 = (-b + sqrt(discriminant)) / (2 * a);
root2 = (-b - sqrt(discriminant)) / (2 * a);
printf("root1 = %.2f\nroot2 = %.2f\n", root1, root2);
}
else if(discriminant == 0) {
root1 = root2 = -b / (2 * a);
printf("root1 = root2 = %.2f\n", root1);
}
else if(discriminant < 0) {
float real = -b / (2 * a);
float imaginary = sqrt(-discriminant) / (2 * a);
printf("root1 = %.2f+%.2fi\nroot2 = %.2f-%.2fi\n", real, imaginary, real, imaginary);
}
}
int main(void) {
float a = 3, b = 5, c = -9;
quadratic_equation_roots(a, b, c);
printf("\n");
a = 3; b = 5; c = 7;
quadratic_equation_roots(a, b, c);
printf("\n");
a = 2; b = 4; c = 2;
quadratic_equation_roots(a, b, c);
return 0;
}
/*
run:
root1 = 1.09
root2 = -2.76
root1 = -0.83+1.28i
root2 = -0.83-1.28i
root1 = root2 = -1.00
*/