本题目要求一元二次方程ax2+bx+c=0的根,结果保留2位小数。

输入格式:

输入在一行中给出3个浮点系数a、b、c,中间用空格分开。

输出格式:

根据系数情况,输出不同结果:

1)如果方程有两个不相等的实数根,则每行输出一个根,先大后小;

2)如果方程有两个不相等复数根,则每行按照格式“实部+虚部i”输出一个根,先输出虚部为正的,后输出虚部为负的;

3)如果方程只有一个根,则直接输出此根;

4)如果系数都为0,则输出"Zero Equation";

5)如果a和b为0,c不为0,则输出"Not An Equation"。

输入样例1:

2.1 8.9 3.5

输出样例1:

-0.44
-3.80

输入样例2:

1 2 3

输出样例2:

-1.00+1.41i
-1.00-1.41i

输入样例3:

0 2 4

输出样例3:

-2.00

输入样例4:

0 0 0

输出样例4:

Zero Equation

输入样例5:

0 0 1

输出样例5:

Not An Equation

代码长度限制

16 KB

时间限制

400 ms

内存限制

64 MB

首先进行思路分析:

关键:利用求根公式书写  △=b²-4ac

45条件为特殊情况,123条件分别根据 △>0,△<0,△=0来写代码。

特别注意:1.求根公式规定a≠0   2.注意再△<0有纯虚数情况。

以下是我的代码

#include<iostream>
#include <math.h>   //开方,幂函数头文件
using namespace std;
double pow( double bottom, double power );  //幂函数
int main()
{double a,b,c,sum,a1,a2;    //a1,a2为两根cin>>a>>b>>c;
if(a==0&&b==0&&c==0)        //第四种情况
{cout<<"Zero Equation";
}
else if(a==0&&b==0&&c!=0)   //第五种情况
{cout<<"Not An Equation";
}
else if(a==0&&b!=0&&c!=0)   //因为两根公式a≠0,此为特殊情况
{a1=(-c)/b;printf("%.2lf\n",a1);  //一个根即可,即样例三
}
else         //可用两个公式
{sum=pow(b,2)-4*a*c;    //sum=b²-4acif(sum>0)              //△>0{double derta=sqrt(sum);a1=(-b-derta)/(2*a);a2=(-b+derta)/(2*a);if(a1>=a2){printf("%.2lf\n",a1);printf("%.2lf\n",a2);}else{printf("%.2lf\n",a2);  printf("%.2lf\n",a1);}}else if(sum==0)        //△=0{ a1=(-b)/(2*a);printf("%.2lf\n",a1);    } else                  //△<0{sum=-sum;          //取△的绝对值double derta=sqrt(sum);a1=(-b)/(2*a);a2=(derta)/(2*a);if(a1!=0){printf("%.2lf+%.2lfi\n",a1,a2);printf("%.2lf-%.2lfi\n",a1,a2);}else               //注意:纯虚数 {printf("0.00+%.2lfi\n",a2);printf("0.00-%.2lfi\n",a2);}
}
}
}

7-88 求一元二次方程的根相关推荐

  1. 计算概论(A)/基础编程练习1(8题)/4:求一元二次方程的根

    1 #include<stdio.h> 2 #include<math.h> 3 int main() { 4 // 待解方程数目 5 int n; 6 scanf(" ...

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

    [题目链接] OpenJudge NOI 1.4 20:求一元二次方程的根 [题目考点] 1. 一元二次方程求根 包括求实根与虚根 2. if-else if-else语句 3. 浮点数比较 [解题思 ...

  3. 7-157 求一元二次方程的根 (20 分)

    7-157 求一元二次方程的根 (20 分) 本题目要求一元二次方程ax2+bx+c=0的根,结果保留2位小数. 输入格式: 输入在一行中给出3个浮点系数a.b.c,中间用空格分开. 输出格式: 根据 ...

  4. c语言学习-求一元二次方程的根

    求一元二次方程的根 程序流程图: 代码: #include<stdio.h> #include<math.h> void main() {float a,b,c,s,x1,x2 ...

  5. 实验3-1 求一元二次方程的根 (20 分)

    实验3-1 求一元二次方程的根 (20 分) 本题目要求一元二次方程ax^2+bx+c=0的根,结果保留2位小数. 输入格式: 输入在一行中给出3个浮点系数a.b.c,中间用空格分开. 输出格式: 根 ...

  6. 例题(8.3) 求一元二次方程的根 (1051)

    题目 - 例题(8.3) 求一元二次方程的根 (1051)   来源 计算概论05 描述 利用公式  x1 = (-b + sqrt(b*b-4*a*c))/(2*a)  x2 = (-b - sqr ...

  7. Python 求一元二次方程的根(包括虚根)

    如图所示,求一元二次方程的根(包括虚根),代码如下: import math a = float(input()) b = float(input()) c = float(input()) delt ...

  8. Java求一元二次方程的根

    求一元二次方程的根. [问题描述]编写程序,从键盘输入三个系数ax2+bx+c=0,计算方程的解并输出.需要考虑方程有虚根.方程有实根.方程是一元一次方程.没有根等.输出方程的解并保留6位小数. im ...

  9. 25268 Problem E 例题3-5 求一元二次方程的根

    问题 E: 例题3-5 求一元二次方程的根 时间限制: 1 Sec  内存限制: 128 MB 题目描述 求一元二次方程ax2+bx+c=0的根,三个系数a, b, c由键盘输入,且a不能为0,且保证 ...

  10. 7-1 求一元二次方程的根 (20 分)

    7-1 求一元二次方程的根 (20 分) #include "stdafx.h" #include "math.h" int _tmain(int argc, ...

最新文章

  1. 2022-2028年中国渣油行业市场研究及前瞻分析报告
  2. XXX语录,可以不信,但不能不看
  3. 成功解决RuntimeWarning: divide by zero encountered in double_scalars
  4. 集成学习-Bagging集成学习算法随机森林(Random Forest)
  5. socket python 收 发 队列 线程_对于Python中socket.listen()与多线程结合的困惑?
  6. C# 三层级架构问题之 能加载文件或程序集或它的某一个依赖项。系统找不到指定的文件
  7. [渝粤教育] 盐城工学院 无机及分析化学C 参考 资料
  8. 【MySQL】ERROR 1055 (42000) ROUP BY clause this is incompatible with sql_mode=only_full_group_by
  9. 计算机主板 方便用户自己安装的是,电脑水冷安装教程步骤解析【图文】
  10. 《Java语言程序设计》(基础篇原书第10版)第九章复习题答案
  11. 美赛论文格式基本要求
  12. 矩阵知识:线性变换、相似矩阵、对角矩阵、逆矩阵
  13. matlab求n阶行列式,发福利了,线性代数n阶行列式计算器!(需要的拿走吧)
  14. linux 查看CPU使用率
  15. 专项训练——判断推理
  16. TypeScript的枚举
  17. 卸载windows 自带 内置软件应用 2022,windows垃圾清理技巧
  18. 20000字干货,数据分析 Pandas 75个高频操作都在这儿了!
  19. 电力爱陆通公专一体模块,国网加密模块,国网硬件加密模块的工作原理
  20. Jetson Nano系列教程4-生死看淡,不服就干之I2C

热门文章

  1. Ubuntu18.04安装专业版pycharm【免费】
  2. SlideBox 间隔滚动效果
  3. 交换机的工作原理是什么,它有什么功能与作用?
  4. 知识关联视角下金融证券知识图谱构建与相关股票发现
  5. CND的定义,原理和好处和CDN回源
  6. python传奇自动打怪脚本_大漠传奇自动打怪源码分享
  7. 【调剂】上海应用技术大学2021年硕士研究生招生考试调剂信息
  8. 使用clusterProfiler进行KEGG富集分析
  9. 微信小程序开发者代码管理中,不想要的项目怎么删除
  10. 迷宫(Maze)项目实现