强制类型转换括号问题(一元二次方程解)
本帖最后由 一世轻尘 于 2021-1-4 18:48 编辑为什么40行不能写成x=(float)(-b/(2*a))?{:10_254:}
#include<stdio.h>
#include<math.h>
void q(int a,int b,int c);
void w(int a,int b,int c);
void e(int a,int b,int c);
int main()
{
int a,b,c;
scanf("%d%d%d",&a,&b,&c);
if(b*b-4*a*c>0)
q(a,b,c);
else if(b*b-4*a*c==0)
w(a,b,c);
else
{
e(a,b,c);
}
return 0;
}
void q(int a,int b,int c)
{
float x1,x2;
x1=(float)(-b+sqrt(b*b-4*a*c))/(2*a);
x2=(float)(-b-sqrt(b*b-4*a*c))/(2*a);
printf("x1=%.3f x2=%.3f",x1,x2);
}
void w(int a,int b,int c)
{
float x1,x2;
x1=(float)-b/2*a;
x2=x1;
printf("x1=%.3f x2=%.3f",x1,x2);
}
void e(int a,int b,int c)
{
float x1,x2;
float x;
x=(float)-b/(2*a);
x1=(float)(sqrt(fabs(b*b-4*a*c)))/(2*a);
x2=(float)(sqrt(fabs(b*b-4*a*c)))/(2*a);
printf("x1=%.3f+%.3fi x2=%.3f-%.3fi",x,x1,x,x2);
} x=(float)-b/(2*a);
这样写是有问题的
你这样写强制类型转换是对运算结果的类型转换,但是 -b/(2*a) 是整数除法,结果是不对的,例如8/3结果是2,19/20结果是0,这样显然是不对的
表达式中有乘除的时候,若全都是int类型则需要加入一个float,例如可以写成 x=-1.0*b/(2*a); 本帖最后由 一世轻尘 于 2021-1-5 14:23 编辑
此贴可忽略 sunrise085 发表于 2021-1-5 11:06
x=(float)-b/(2*a);
这样写是有问题的
你这样写强制类型转换是对运算结果的类型转换,但是 -b/(2*a) 是整 ...
我们老师课件上是这么写的,结果也没问题,但是我一加上括号结果就成0了,这是为啥?
页:
[1]