| 查看: 1106 | 回复: 4 | ||||
| 本帖产生 1 个 博学EPI ,点击这里进行查看 | ||||
| 当前只显示满足指定条件的回帖,点击这里查看本话题的所有回帖 | ||||
[交流]
C++编程
|
||||
|
求解一元二次方程。 一元二次方程的定义为: ax2+bx+c=0 (1)如果b2 -4ac>0,方程有两个不同的实根,分别是: (2)如果b2 -4ac< 0,方程没有实根,但有虚根; (3)如果b2 -4ac= 0,方程有一个实根。 请你编写一个程序,使其能求出多个二次方程的根。该程序要询问用户是否想继续解下一个方程。用户输入1来继续,输入其它数字,则终止程序。程序要求用户输入a,b和c,然后根据前面的条件计算,并输出答案。 要求:使用类实现, (1) a,b,c为该类的私有成员变量; (2) 求根的实现为该类的成员函数,形式为: //函数返回值:实根的个数; //参数:x- 用以返回实根值的数组; long CalResult(float x[]); (3) 该类还包含有参构造函数、析构函数。 谢谢 请尽快 |
» 猜你喜欢
材料学硕318求调剂
已经有9人回复
0856求调剂285
已经有7人回复
0856化工专硕求调剂
已经有7人回复
313求调剂
已经有3人回复
材料化工调剂
已经有10人回复
295求调剂
已经有6人回复
311求调剂
已经有6人回复
0856调剂
已经有4人回复
307求调剂
已经有5人回复
281求调剂
已经有4人回复
» 抢金币啦!回帖就可以得到:
澳大利亚科廷大学招收全奖博士(采矿与冶金工程专业)
+1/277
农药产品分析实验人员招聘
+5/225
求助哪里可以做光催化产氢的放大实验
+1/83
化生学院蒋老师课题组招收研究生
+1/82
太原科技大学材料科学与工程学院招收金属材料类博士一名
+1/81
长春工业大学化学工程学院招收26年硕士调剂生
+1/80
哈尔滨工业大学航天学院复合材料与结构研究所招硕士生
+1/32
中山大学化学工程与技术学院杰青欧阳钢锋/吴鑫课题组博士后招聘启事
+1/32
吉林师范大学宽禁带半导体材料生长与器件实验室招收2026年入学申请考核制博士生4名
+2/30
澳门理工大学人工智能智慧康养方向26 年9月入学博士招生 奖学金
+1/28
首师大26级硕士
+1/27
look 26届 || 计算机、电子信息类、电科、控制、通信考研T j信息醇:1o33 7747 o3
+1/16
电子科技大学材料学院SFT创新中心招收博士生及科研助理 长期有效
+1/12
look 26届计算机、电子信息类、电科、控制、通信考研T j信息醇:10+33+77+47+03
+1/10
推荐一款可以AI辅助写作的Latex编辑器SmartLatexEditor,超级好用,推荐试试
+1/9
26届计算机、电子信息类、电科、控制、通信考研T j信息醇:10+33+77+47+03
+1/9
西安工程大学环境与化学工程学院26年硕士研究生招生咨询
+1/6
中国科学院大学化学科学学院:接收有机化学专业调剂生(限报考中科院系统考生)
+1/4
中科院深圳先进技术研究院成会明院士/唐永炳杰青团队拟招聘博士后若干名。
+1/3
深圳大学何传新课题组诚聘博士后、(副)研究员
+1/1
babyrabbit2006(金币+50, 博学EPI+1):谢谢了啊 2010-12-20 20:36:07
|
// 二次根.cpp : Defines the entry point for the console application. // #include "stdafx.h" #include "math.h" #include using namespace std; class Cercigeng { public: Cercigeng(float aa, float bb, float cc); ~Cercigeng(); //函数返回值:实根的个数; //参数:x- 用以返回实根值的数组; long CalResult(float x[]); private: float a; float b; float c; }; Cercigeng::Cercigeng(float aa, float bb, float cc) { a=aa; b=bb; c=cc; } Cercigeng::~Cercigeng() { } long Cercigeng::CalResult(float x[]) { float delta = 0; long geshu=0; delta = b*b-4.0*a*c; if (delta < 0) { geshu = 0; } else if(fabs(delta)<1e-10) { x[0] = (-b+sqrt(delta))/2.0/a; geshu = 1; } else { x[0] = (-b+sqrt(delta))/2.0/a; x[1] = (-b-sqrt(delta))/2.0/a; geshu = 2; } return geshu; } int main(int argc, char* argv[]) { cout<<"求解方程的根!\n"<<"请输入a,b,c"; float a,b,c; cin>>a>>b>>c; Cercigeng fangcheng(a,b,c); float xx[1]; long GeShu = fangcheng.CalResult(xx); if (GeShu = 0) { cout<<"无实根!\n"; } else if(GeShu = 1) { cout<<"方程有一个实根为"< else { cout<<"方程有二个实根,分别为"< cout<<"如果继续,请输入1!否则输入其它数字\n"; int jixu=0; cin>>jixu; for (;(jixu-1)!=0 ![]() { cout<<"求解方程的根!\n"<<"请输入a,b,c"; cin>>a>>b>>c; Cercigeng fangcheng(a,b,c); GeShu = fangcheng.CalResult(xx); if (GeShu = 0) { cout<<"无实根!\n"; } else if(GeShu = 1) { cout<<"方程有一个实根为"< else { cout<<"方程有二个实根,分别为"< } return 0; } 试试吧,应该没有问题的,我写了一下,但是没有编译运行,好运! |
5楼2010-12-18 18:11:13
2楼2010-12-17 21:39:15
curton
主管区长 (文坛精英)
-

专家经验: +151 - 博学EPI: 23
- 应助: 195 (高中生)
- 贵宾: 49.033
- 金币: 81392.2
- 帖子: 20300
- 在线: 15504.3小时
- 虫号: 950839
★ ★ ★ ★ ★ ★ ★ ★ ★ ★
YUE-jf(金币+10):奖励 2010-12-21 14:02:16
YUE-jf(金币+10):奖励 2010-12-21 14:02:16
|
#include #include using namespace std; float x1,x2,disc,p,q; int main() {void greater_than_zero(float,float); void equal_to_zero(float,float); void smaller_than_zero(float,float); float a,b,c; cout<<"input a,b,c:"; cin>>a>>b>>c; disc=b*b-4*a*c; cout<<"root:"< { greater_than_zero(a,b); cout<<"x1="< else if (disc==0) {equal_to_zero(a,b); cout<<"x1="< else {smaller_than_zero(a,b); cout<<"x1="< cout<<"x2="< } return 0; } void greater_than_zero(float a,float b) /* 定义一个函数,用来求disc>0时方程的根 */ {x1=(-b+sqrt(disc))/(2*a); x2=(-b-sqrt(disc))/(2*a); } void equal_to_zero(float a,float b) /* 定义一个函数,用来求disc=0时方程的根 */ { x1=x2=(-b)/(2*a); } void smaller_than_zero(float a,float b) /* 定义一个函数,用来求disc<0时方程的根 */ { p=-b/(2*a); q=sqrt(-disc)/(2*a); } |
3楼2010-12-17 21:51:11
curton
主管区长 (文坛精英)
-

专家经验: +151 - 博学EPI: 23
- 应助: 195 (高中生)
- 贵宾: 49.033
- 金币: 81392.2
- 帖子: 20300
- 在线: 15504.3小时
- 虫号: 950839
4楼2010-12-17 21:52:27













回复此楼