zoj 1544 || poj 1860 Currency Exchange(Bellman-ford)

211 篇文章 0 订阅

我啊,自作聪明用dij先最短路,然后用bellman的判断负环判断 = =。。。结果WA得很惨。

 

后来改成bellman-ford,党的那种 = =。。

 

if( ( dis[x] - comm) * rate > dis[y] + 1e-5 ) 写成了if( ( dis[x] - comm) * rate > dis[y]  ) 居然TLE了 = =。。找了半天错。无语了都。为什么捏。待考证 = =。

 


/*下面的想法是错误的。

在poj上表示完全无影响,要不要1e-5都能过。zoj上,从1e-5到1e-14都能AC,而且是0ms。到1e-15就TLE了。

应该是这样的,比如加了1e-5,加了这个判断就是比较到小数位后5位就停止了,不用比较后来的位数。如果直接用>的话,就会把小数后所有的位数比较一遍,意义不大还耗费时间。

这个被GB否定了  T T.。。。*/

 


double精度在15-16位,大小在1.7E-308~1.7E+308,如果esp == 1e-15,则比较的结果不准呢。这个应该是造成TLE的问题吧。可能一直比较,得不到要的结果。。。


 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值