OpenJudge NOI 1.4 20:求一元二次方程的根

【题目链接】

OpenJudge NOI 1.4 20:求一元二次方程的根

【题目考点】

1. 一元二次方程求根

包括求实根与虚根

2. if…else if…else语句
3. 浮点数比较

【解题思路】

首先求 Δ = b 2 − 4 a c \Delta = b^2-4ac Δ=b24ac

  • 如果 Δ \Delta Δ为0,输出两个相等的根;
  • 如果 Δ \Delta Δ大于0,输出两个不等的实根,先输出较大实根,再输出较小实根。
  • 如果 Δ \Delta Δ小于0,输出两个虚根。先输出虚部系数较大的虚根,再输出虚部系数较小的虚根。

【题解代码】

解法1:
#include<bits/stdc++.h>
using namespace std; 
int main()
{
  	double a, b, c;
  	cin>>a>>b>>c;
  	double delta = b*b - 4*a*c;
  	if(fabs(delta) < 0.00001)//如果delta为0,输出相等的实根 
  		printf("x1=x2=%.5f", -b/(2*a));
	else if(delta > 0)//输出不同的实根
	{
	    double x_small = (-b-sqrt(delta))/(2*a);//x_small保存较小的实根 
		double x_big = (-b+sqrt(delta))/(2*a);//x_big保存较大的实根 
	   	if(x_small > x_big)//刚刚求出的x_small与x_big没有确定的大小关系,此处操作可以使得x_small一定小于x_big 
		{//如果x_small大于x_big,那么将二者交换。 
			double temp = x_small;
			x_small = x_big;
			x_big = temp;
		}
		printf("x1=%.5f;x2=%.5f", x_big, x_small);//先输出较大实根,再输出较小实根 
	}
	else//输出虚根 
	{
		double shibu = -b/(2*a), xubu = sqrt(4*a*c-b*b)/(2*a);
		if(fabs(shibu) < 0.00001)//如果实部很接近0,将其赋值为0。如果不这样做会由于系统误差导致输出的shibu不为0. 
			shibu = 0;
		printf("x1=%.5f+%.5fi;x2=%.5f-%.5fi",shibu, xubu, shibu, xubu);//实部为0也不可省略 
	} 
    return 0;
}
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值