C语言中浮点数精度进行截断输出
今日在做ACM/ICPC的题目时,遇到了这样的情况:程序求得的结果是一个浮点数,但题目要求以整数形式输出(取不小于该结果的最小整数)。这是个很简单的问题。也许很多人会采用float强制转型为int再加1的办法解决。然而我一向觉得强制转型是种很不优美的办法,因此采用了类似如下代码的办法:
printf("The result is %.0f.\n", result); // result是求得的浮点数结果
采用控制输出精度的办法,原来以为没什么问题,然而结果却一直是Wrong Answer。后来才发现,原来在C的格式化输出中,若采用"%m.nf"的形式对浮点(或双精度)数进行截断输出,输出的最后一位是取四舍五入的结果的。比如在上面的代码中,若result = 3.2,那么输出就为
The result is 3.
若result = 3.5,那么输出则为
The result is 4.
把代码改为
printf("The result is %.0f.\n", ceilf(result));
问题就解决了(当然还要包含math.h头文件并使用g++编译器而不是gcc)。这么一个小小的问题,害我在一道超简单的题上提交了几乎10次(此题是北大acm网站上的1005题I Need a Houseboat),真是有点郁闷。不过还好没占用多长时间,何况也知道了一个细节性的知识(也算是知识吧),还算值得啦。
相关推荐
风雨断肠人 2020-10-13
Cwiky 2020-07-18
Greatemperor 2020-07-04
RuoShangM 2020-06-28
paopao00 2020-06-08
长安长夜Saint 2020-06-07
flyingssky 2020-06-04
fanhuasijin 2020-05-30
breakpoints 2020-05-19
cyydjt 2020-05-18
tvk 2020-05-11
eroshn 2020-05-06
qingsongzdq 2020-04-26
ericasadun 2020-04-26
lynjay 2020-04-26
choupiaoyi 2020-04-26
jyj00 2020-04-20
choupiaoyi 2020-04-18
qingsongzdq 2020-04-18