C++求一元二次方程的根
#include<iostream>#include<cmath>usingnamespacestd;voidmain(){inta,b,c;floatx,y;float...
#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 <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;
}
}
}
初学 帮我看下哪儿错了 谢谢 展开
3个回答
展开全部
#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 还没有给值 怎么可以计算呢? 看看我给你的答案啊! 呵呵 高中数学学得不错啊! 情况分析的很到位! 不错! 分类分的 恰到好处!
#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 还没有给值 怎么可以计算呢? 看看我给你的答案啊! 呵呵 高中数学学得不错啊! 情况分析的很到位! 不错! 分类分的 恰到好处!
Sievers分析仪
2024-10-13 广告
2024-10-13 广告
是的。传统上,对于符合要求的内毒素检测,最终用户必须从标准内毒素库存瓶中构建至少一式两份三点标准曲线;必须有重复的阴性控制;每个样品和PPC必须一式两份。有了Sievers Eclipse内毒素检测仪,这些步骤可以通过使用预嵌入的内毒素标准...
点击进入详情页
本回答由Sievers分析仪提供
展开全部
这是一道经典题
我在很多地方都看到过这道题。
代码如下:
#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");
}
}
下面是程序的运行效果图:
我在很多地方都看到过这道题。
代码如下:
#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");
}
}
下面是程序的运行效果图:
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
sqrt(delta) delta不能为负数。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询
广告 您可能关注的内容 |