G_Smile 发表于 2020-3-8 20:46:13

如何比较两个浮点数近似相等

如何比较两个浮点数近似相等

major_lyu 发表于 2020-3-8 21:34:03

本帖最后由 major_lyu 于 2020-3-8 21:35 编辑

给一个精度p.也就是两个数之差小于这个精度就认为相等。例如精度10E-3
#include <stdio.h>
#include <math.h>

_Bool isApproEqual(float, float);
int main()
{
    float a;
    float b;
    printf("input two float numbers:\n");
    scanf("%f %f", &a, &b);
    if(isApproEqual(a,b))
    {
      printf("%f and %f are approximately equal\n", a, b);
    }
    else
    {
      printf("%f and %f are not approximately equal\n", a, b);
    }
    return 0;
}

_Bool isApproEqual(float a, float b)
{
    float p =1E-3;
    return (fabs(a-b) < p); //两数差的绝对值小于精度返回true,否则返回false
}
.

G_Smile 发表于 2020-7-7 17:09:13

major_lyu 发表于 2020-3-8 21:34
给一个精度p.也就是两个数之差小于这个精度就认为相等。例如精度10E-3
.

谢谢大佬!
页: [1]
查看完整版本: 如何比较两个浮点数近似相等