C++求一元二次方程的根

#include <iostream>
#include <cmath>
using namespace std;
void main()
{
int a,b,c;
float x,y;
float delta;
delta=b*b-4*a*c;
cout<<"请输入一元二次方程对应常量"<<endl;
cin>>a>>b>>c;
if(a==0&&b==0&&c!=0)
cout<<"方程无根"<<endl;
else if(a==0&&b!=0)
{
x=-c/b;
cout<<x<<endl;
}
else
{
if(delta=0)
{
x=(-b+sqrt(delta))/(2*a);
cout<<"有二个相等的实根"<<x<<endl;
}
else if(delta<0)
{
x=(-b+sqrt(delta))/(2*a);
y=(-b-sqrt(delta))/(2*a);
cout<<"方程有2个不等的复根"<<x<<y<<endl;
}
else
{
x=(-b+sqrt(delta))/(2*a);
y=(-b-sqrt(delta))/(2*a);
cout<<"方程有2个不等的根"<<x<<y<<endl;
}
}
}
初学 帮我看下哪儿错了 谢谢

#include <iostream>
#include <cmath>
using namespace std;
int main()
{
int a,b,c;
float x,y;
float delta;

cout<<"请输入一元二次方程对应常量"<<endl;
cin>>a>>b>>c;
if(a==0&&b==0&&c!=0)
cout<<"方程无根"<<endl;
else if(a==0&&b!=0)
{
x=-c/b;
cout<<x<<endl;
}
else
{
delta=b*b-4*a*c;
if(delta==0)
{
x=(-b+sqrt(delta))/(2*a);
cout<<"有二个相等的实根"<<x<<endl;
}
else if(delta<0)
{
x=(-b+sqrt(delta))/(2*a);
y=(-b-sqrt(delta))/(2*a);
cout<<"方程有2个不等的复根"<<x<<y<<endl;
}
else
{
x=(-b+sqrt(delta))/(2*a);
y=(-b-sqrt(delta))/(2*a);
cout<<"方程有2个不等的根"<<x<<y<<endl;
}
}
return 0;
}
你的那个if 里面 有错 你自己看看啊 还有那个delta a b c 还没有给值 怎么可以计算呢? 看看我给你的答案啊! 呵呵 高中数学学得不错啊! 情况分析的很到位! 不错! 分类分的 恰到好处!
温馨提示:答案为网友推荐,仅供参考
第1个回答  2019-06-02
这是一道经典题
我在很多地方都看到过这道题。
代码如下:
#include<stdio.h>
#include<math.h>
void
f(float
m,float
n,float
l)
{
float
x1,x2,q,p,deta;
deta=n*n-4*m*l;
if(deta<0)
printf("方程无解。\n");
else
{
q=sqrt(deta)/(2*m);
p=-n/(2*m);
x1=p+q;
x2=p-q;
}
if(deta==0)
printf("方程有一个解。\nx=%g\n",x1);
if(deta>0)
printf("方程有两个解。\nx1=%g,x2=%g\n",x1,x2);
}
main()
{
printf("输入a,b,c:");
float
a,b,c;
scanf("%g%g%g",&a,&b,&c);
if(a!=0)f(a,b,c);
else
{
if(b!=0)printf("方程是一元一次方程。\n方程的解是:X=%g。\n",-c/b);
if(b==0)printf("参数A,B,C不能够成方程。\n");
}
}
下面是程序的运行效果图:
第2个回答  2010-03-20
sqrt(delta) delta不能为负数。
相似回答