我在c上尝试了一些计算,我的代码如下
#include <stdio.h>
#include <math.h>
int main(void)
{
float a = 1.8;
float b = 3.3;
float c = 1.5;
float d = 5.9;
float e = 2.6;
float result = a / (a + (abs(a - b) / (b + (pow(c, 5) / (e + (pow(d, 2) / (b + (pow(c, 3) / 4))))))));
float result2 = a / (a + ((-1) * (a-b)) / (b + ((c * c * c * c * c) / (e + ((d * d) / (b + ((c * c * c) / 4)))))));
printf("Result = %.4f\n", result);
printf("Result2 = %.4f\n", result2);
system("pause");
return(0);
}
Run Code Online (Sandbox Code Playgroud)
Result2是正确的结果.那么为什么结果和结果2是不同的?我在做什么是错的?
abs适用于int:
int abs(int j);
Run Code Online (Sandbox Code Playgroud)
而你fabs或fabsf将使用的是:
double fabs(double x);
float fabsf(float x);
Run Code Online (Sandbox Code Playgroud)
编辑:
更改abs为之后fabs,本地测试给出:
[pengyu@GLaDOS tmp]$ gcc a.c -lm -Wall -pedantic
[pengyu@GLaDOS tmp]$ ./a.out
Result = 0.8272
Result2 = 0.8272
Run Code Online (Sandbox Code Playgroud)