不枉风来水顺 发表于 2023-9-28 19:26:16

帮我写个完美答案吧!!!

请写一段程序来判断表达式是否相等。

输入格式:
只有一行,为三个用空格分隔的浮点数a,b,c(0<a,b,c<100)。

输出格式:
也只有一行,如果 a - b 等于c ,则输出yes,否则输出no。

我怎么写都只有60分
#include<stdio.h>

int main ()
{
    float a,b,c;
    scanf("%f %f %f",&a,&b,&c);
    double num = a-b;

    if(num == c)
    {
      printf("yes");
    }
    else if (num != c)
    {
      printf("no");
    }
    return 0;
}
{:5_99:}

isdkz 发表于 2023-9-28 19:26:25

你的程序存在精度问题,因为浮点数的计算可能会出现舍入误差。正确的做法是将浮点数转换为整型再进行计算。以下是正确的代码:

#include <stdio.h>

int main() {
    float a, b, c;
    scanf("%f %f %f", &a, &b, &c);
    int x = a * 100 + 0.5;
    int y = b * 100 + 0.5;
    int z = c * 100 + 0.5;
    if (x - y == z) {
      printf("yes");
    } else {
      printf("no");
    }
    return 0;
}


这里将浮点数乘以100再加上0.5的方法可以将浮点数四舍五入转换为整型,避免了精度问题。

Mike_python小 发表于 2023-9-28 19:27:02

判断表达式是否相等的C/C++程序


#include <stdio.h>

int main() {
    float a, b, c;
    scanf("%f %f %f", &a, &b, &c);
   
    float diff = a - b;
   
    if (diff == c) {
      printf("yes");
    } else {
      printf("no");
    }
   
    return 0;
}


以上是你提供的代码,如果得分只有60分,可能是由于以下问题:

1. 数据类型不一致:在计算 a - b 后,将结果存储在 double 类型的变量 num 中,而条件判断时使用了 float 类型的变量 c。这样会使数据类型不一致,可能导致判断错误。解决方法是将 num 的数据类型也改为 float。

2. 浮点数比较:直接使用 == 运算符判断两个浮点数是否相等可能会存在精度问题。由于浮点数的表示方式,可能会出现微小的误差。应该尽量避免直接比较浮点数的相等性,而是判断它们之间的差值是否在某个可接受的范围内。例如,可以定义一个较小的精度阈值比如 1e-6,然后判断 fabs(diff - c) < 1e-6 来代替 diff == c。

修改后的代码如下所示:


#include <stdio.h>
#include <math.h>

int main() {
    float a, b, c;
    scanf("%f %f %f", &a, &b, &c);
   
    float diff = a - b;
    float threshold = 1e-6;// 定义一个精度阈值
   
    if (fabs(diff - c) < threshold) {
      printf("yes");
    } else {
      printf("no");
    }
   
    return 0;
}


通过上述修改,你的程序应该能正确判断表达式是否相等。如果还有其他问题或疑惑,请随时提问。

球一个最佳答案谢谢啦!这对我非常重要!{:10_254:}{:10_254:}{:10_254:}

不枉风来水顺 发表于 2023-9-28 19:29:58

isdkz 发表于 2023-9-28 19:26
你的程序存在精度问题,因为浮点数的计算可能会出现舍入误差。正确的做法是将浮点数转换为整型再进行计算。 ...

为什么非要加上那个0.5呢,我在我的PTA作业里面把0.5都删掉了也能的满分的,giegie能告诉我吗
页: [1]
查看完整版本: 帮我写个完美答案吧!!!