求一元二次方程(信息学奥赛一本通-T1058)

该博客介绍了如何使用C++编程求解一元二次方程ax^2 + bx + c = 0的根,要求结果精确到小数点后5位。输入包含三个浮点数a, b, c,输出包括可能的相等根、不同根和无实根的情况,样例给出了输入和正确输出。" 106107966,8253038,LeetCode 328:奇偶链表解决方案,"['链表问题', '数据结构', '算法', 'LeetCode']
摘要由CSDN通过智能技术生成

【题目描述】
求一元二次方程ax^2+bx+c=0的根,其中a不等于0。结果要求精确到小数点后5位。

【输入】
输入一行,包含三个浮点数a, b, c(它们之间以一个空格分开),分别表示方程ax^2+bx+c=0的系数。

【输出】
输出一行,表示方程的解。

若两个实根相等,则输出形式为:“x1=x2=…x1=x2=…”;

若两个实根不等,在满足根小者在前的原则,则输出形式为:“x1=…;x2=…x1=…;x2=…“;

若无实根输出“No answer!”。

所有输出部分要求精确到小数点后5位,数字、符号之间没有空格。

【输入样例】
-15.97 19.69 12.02

【输出样例】
x1=-0.44781;x2=1.68075

【源程序】

#include <iostream>
#include <cstdio>
#include <cmath>
#define precision_1 1e-12//自己定一精度,用于判断浮点数大小
#define precision_2 1e-6//自己定一精度,用于判断浮点数大小
/*
    双精度浮点数表示法:1bit符号位,11bit指数位(用阶码表示),52bit小数部分(尾数)。
    因此一个规格化的单精度浮点数x的真值为x=((-1)^S)(1.M)(2^(E-127))
    显然,x永远也不可能为绝对0。
    针对上面的描述,当阶码E为全0且尾数M也全0时,可以认为表示的真值x为计算机中的绝对0值,
    再结合符号位S,有正0和负0之分; 
*/
/*
    x1和x2是两浮点数,precision是自设的精度。
    可以用 fabs(x1-x2)<=precision来判断x1和x2是否相等。
    如果要求更高的精度,把prec
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值