C语言中如何进行浮点数比较

avatar
作者
猴君
阅读量:0

在 C 语言中,由于浮点数的表示和精度问题,直接使用 == 进行浮点数比较可能会导致不准确的结果

#include<stdio.h> #include <math.h>  // 定义一个非常小的正数作为误差范围 const double EPSILON = 1e-9;  int float_equal(double a, double b) {     // 如果两个浮点数之间的差值的绝对值小于 EPSILON,则认为它们相等     return fabs(a - b) < EPSILON; }  int main() {     double num1 = 0.1 + 0.2;     double num2 = 0.3;      if (float_equal(num1, num2)) {         printf("num1 equals num2\n");     } else {         printf("num1 does not equal num2\n");     }      return 0; } 

在这个例子中,我们定义了一个 EPSILON 常量作为误差范围。float_equal 函数接受两个浮点数参数,并返回它们是否相等的判断结果。我们通过计算它们之间的差值的绝对值并与 EPSILON 进行比较来实现这一功能。如果差值的绝对值小于 EPSILON,则认为这两个浮点数相等。

广告一刻

为您即时展示最新活动产品广告消息,让您随时掌握产品活动新动态!