2021-10-13

浮点数在条件判断语句中的使用
浮点数是近似数,有时候并不能像整数一样直接去比较大小,如:

double a = 3.5;
double b = 3.499999999999999999999999;
if (a > b)
	printf("true\n");
else
	printf("false\n");

这是上面一段代码执行的结果!

上面代码运行后,控制台输出是false,与我们预想的结果是不一样的,这种情况对于一些对数据精确度要求高会产生很大影响!
下面是一种解决方案:
原理是高等数学中的极限
在float.h库中,提供 DBL_EPSILON和FLT_EPSILON两个最小精度,这个也可以自己定义,根据实际需求。

	double a = 3.5;
	double b = 3.499999999999999999999999;
	if (a > b)
		printf("true\n");
	else
		printf("false\n");
	printf("******** modify **********\n");
	if (fabs(a - b) < DBL_EPSILON)
		printf("true\n");
	else
		printf("false\n");

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值