浮点数精度误差:BestCoder Round #29 1001 || hdu 5170

题目大意
比较a^b与c^d的大小,输出“>””<”“=”.

解题思路
取对数比较b×log(a)和d×log(c),注意浮点数精度误差eps。
浮点数精度误差很好容易理解,就像十进制不能精确表示1/3(0.33333)一样,计算机二进制也不能精确表示和存储1/10,0.999999998,结论是

浮点数是有精度的,不能直接比较相等,只能控制在一定的误差范围内相等。

比如这样的一段代码

这里写图片描述

执行结果是死循环

这里写图片描述

原因就是浮点数有精度误差,不能直接比较相等。

这道题也是这样的一个问题,判断等不等时要控制误差范围eps,只要落在这个范围内就可以认为相等。

参考代码

#include <iostream>
#include <cstdio>
#include <algorithm>
#include <map>
#include <vector>
#include <cstring>
#include<cmath>
#define eps 1e-8
using namespace std;
typedef long long ll;
const int maxn = 50;
int main()
{
  // freopen("input.txt","r",stdin);
   double a,b,c,d;
   while(cin>>a>>b>>c>>d){
    double temp=b*log(a)-d*log(c);
    if(fabs(temp)<eps) puts("=");   //与0等不等
   else if(temp>eps) puts(">");
   else puts("<");
   }
   return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值