一世轻尘 发表于 2021-1-4 18:46:23

强制类型转换括号问题(一元二次方程解)

本帖最后由 一世轻尘 于 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);
}

sunrise085 发表于 2021-1-5 11:06:07

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 11:09:49

本帖最后由 一世轻尘 于 2021-1-5 14:23 编辑

此贴可忽略

一世轻尘 发表于 2021-1-5 12:16:45

sunrise085 发表于 2021-1-5 11:06
x=(float)-b/(2*a);
这样写是有问题的
你这样写强制类型转换是对运算结果的类型转换,但是 -b/(2*a) 是整 ...

我们老师课件上是这么写的,结果也没问题,但是我一加上括号结果就成0了,这是为啥?
页: [1]
查看完整版本: 强制类型转换括号问题(一元二次方程解)