如何用C++求解方程ax^2+bx+c=0的解

 我来答
百度网友e86bed2
2012-05-09 · TA获得超过375个赞
知道小有建树答主
回答量:191
采纳率:0%
帮助的人:81.4万
展开全部
#include<iostream.h>
#include<math.h>
class Equation{
float a,b,c;

public:
float x[2];
Equation(float a1=0.0,float b1=0.0,float c1=0.0)
{
a=a1;
b=b1;
c=c1;
}
~Equation(){}
long CalResult();

};
long Equation::CalResult()
{
long temp;
if ((b*b-4*a*c)==0)
{
temp=1;
x[0]=(float)(-(b/2*a));
return temp;
}
if ((b*b-4*a*c)>0)
{
temp=2;
x[0]=(-b+sqrt(b*b-4*a*c))/(2*a);
x[1]=(-b-sqrt(b*b-4*a*c))/(2*a);
return temp;
}
else
{
temp=0;
}
return temp;
}

int main()
{
float a,b,c;
char ch;
do{
cout<<"请输入一元二次方程系数a"<<endl;
cin>>a;
cout<<"请输入一元二次方程系数b"<<endl;
cin>>b;
cout<<"请输入一元二次方程系数c"<<endl;
cin>>c;
Equation *obj=new Equation(a,b,c);
cout<<"方程有"<<obj->CalResult()<<"个根"<<endl;
if (obj->CalResult()==1)
{
cout<<"X="<<obj->x[0]<<endl;
}
if (obj->CalResult()==2)
{
cout<<"X1="<<obj->x[0]<<endl;
cout<<"X2="<<obj->x[1]<<endl;
}
delete obj;
cout<<"是否继续计算?(1)"<<endl;
cin>>ch;
}while(ch=='1');

return 0;
}
yi_yi901
2012-05-12 · TA获得超过230个赞
知道小有建树答主
回答量:286
采纳率:100%
帮助的人:184万
展开全部
#include<stdio.h>

#include<math.h>
int f(double a,double b,double c,double *x1,double *x2)
{
double d=b*b-4*a*c;
if(d>0)
{
*x1=(-b+sqrt(d))/(2*a);
*x2=(-b-sqrt(d))/(2*a);
return 1;
}
else if(d==0)
{
*x1=*x2=(-b)/(2*a);
return 0;
}
else
return -1;
}
void main()
{ double a1,a2,a3,y1,y2,t;
printf("请输入要解方程的系数:\n");
scanf("%lf%lf%lf",&a1,&a2,&a3);
t=f(a1,a2,a3,&y1,&y2);
if(t>0)
printf("x1=%.10f tx2=%.10f\n",y1,y2);
else if(t==0)
printf("x1=x2=%.4f\n",y1);
else printf("此方程无解!");

}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
李年胜李年胜
2012-05-14
知道答主
回答量:44
采纳率:0%
帮助的人:10.9万
展开全部
同意一下的
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
幽然無聲
2012-05-09 · TA获得超过1880个赞
知道小有建树答主
回答量:862
采纳率:0%
帮助的人:580万
展开全部
dfs
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 2条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式