C语言 计算一元二次方程 ax²+bx+c=0

方法一:常规计算

#include<stdio.h>
#include<math.h>
void main(){
	float a,b,c,d,x1,x2;
	printf("请输入a的值:");
	scanf("%f",&a);
	printf("请输入b的值:");
	scanf("%f",&b);
	printf("请输入c的值:");
	scanf("%f",&c);

	d=b*b-4*a*c;
	if(d>0){
		x1=(-b+sqrt(d))/(2*a);
		x2=(-b-sqrt(d))/(2*a);
		printf("x1=%g,x2=%g",x1,x2);
	}else if(d==0){
		x1=x2=-b/(2*a);
		printf("x1=x2=%g",x1);
	}else{
		printf("无解");
	}
}

在这里插入图片描述

方法二:函数调用,包含共轭复根

#include<stdio.h>
#include<math.h>
float x1,x2,disc,p,q;
void greater_than_zero(float a,float b){
	x1=(-b+sqrt(disc))/(2*a);
	x2=(-b-sqrt(disc))/(2*a);
}
void equal_to_zero(float a,float b){
	x1=x2=(-b)/(2*a);
}
void smaller_than_zero(float a,float b){
	p=-b/(2*a);
	q=sqrt(-disc)/(2*a);
}
int main(){
	float a,b,c;
	printf("input a,b,c:");
	scanf("%f,%f,%f",&a,&b,&c);
	printf("equation:%g*x*x+%g*x+%g=0\n",a,b,c);
	disc=b*b-4*a*c;
	printf("root:\n");
	if(disc>0){
		greater_than_zero(a,b);
		printf("x1=%f\tx2=%f\n",x1,x2);
	}else if(disc==0){
		equal_to_zero(a,b);
		printf("x1=%f\tx2=%f\n",x1,x2);
	}else{
		smaller_than_zero(a,b);
		printf("x1=%f+%f\tx2=%f-%f\n",p,q,p,q);
	}
	return 0;
}

① 两个不等的实根
在这里插入图片描述
② 两个相等的实根
在这里插入图片描述
③ 两个共轭复根
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

码字创文

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

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

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

打赏作者

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

抵扣说明:

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

余额充值