一、解题思路:

C参考代码:

#include <stdio.h>
#include <math.h>
double P, Q, K, X;	//定义全局变量
void d0();
void d1();
void d2();	//声明自定义函数

int main() {
	double a, b, c;
	scanf("%lf %lf %lf", &a, &b, &c);
	P = b * b - 4 * a * c;	//根的判别式:▲=b^2-4ac
	Q = (-b) / (2 * a);	//-b/(2a)
	K = 2 * a;
	X = sqrt(fabs(P)) / K;	//√(b^2-4ac)/2a
	if (P < 0) {
		d0();
	}
	if (P == 0) {
		d1();
	}
	if (P > 0) {
		d2();
	}
	return 0;
}

void d0() {	//▲<0时,方程无实数根,但有2个共轭复根
	printf("x1=%.3lf+%.3lfi x2=%.3lf-%.3lfi", Q, X, Q, X);
}

void d1() {	//▲=0时,方程有两个相等的实数根
	printf("x1=%.3lf x2=%.3lf", Q + X, Q + X);
}

void d2() {	//▲ > 0 时,方程有两个不相等的实数根
	printf("x1=%.3lf x2=%.3lf", Q + X, Q - X);
}

Java参考代码:

import java.util.Scanner;
public class Main {
static double P, Q, K, X; //定义全局变量
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
double a = sc.nextDouble();
double b = sc.nextDouble();
double c = sc.nextDouble();
P = b * b - 4 * a * c; //根的判别式:▲=b^2-4ac
Q = (-b) / (2 * a); //-b/(2a)
K = 2 * a;
X = Math.sqrt(Math.abs(P)) / K; //√(b2-4ac)/2a
if (P < 0) {
d0();
} else if (P == 0) {
d1();
} else {
d2();
}
}

static void d0() { //▲<0时,方程无实数根,但有2个共轭复根
System.out.printf("x1=%.3f+%.3fi x2=%.3f-%.3fi", Q, X, Q, X);
}

static void d1() { //▲=0时,方程有两个相等的实数根
System.out.printf("x1=%.3f x2=%.3f", Q + X, Q + X);
}

static void d2() { //▲ > 0 时,方程有两个不相等的实数根
System.out.printf("x1=%.3f x2=%.3f", Q + X, Q - X);
}
}
点赞(0)
 

0.0分

0 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论