a我考网

 找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 55|回复: 0

[C语言] C语言中浮点数精度进行截断输出

[复制链接]
发表于 2012-7-31 21:48:08 | 显示全部楼层 |阅读模式
 今日在做ACM/ICPC的题目时,遇到了这样的情况:程序求得的结果是一个浮点数,但题目要求以整数形式输出(取不小于该结果的最小整数)。这是个很简单的问题。也许很多人会采用float强制转型为int再加1的办法解决。然而我一向觉得强制转型是种很不优美的办法,因此采用了类似如下代码的办法: " V; \4 `* r0 J" V* D: G( J
  printf(\"The result is %.0f.\\n\", result);    // result是求得的浮点数结果
# _- T" t$ s$ M9 }  采用控制输出精度的办法,原来以为没什么问题,然而结果却一直是Wrong Answer。后来才发现,原来在C的格式化输出中,若采用\"%m.nf \"的形式对浮点(或双精度)数进行截断输出,输出的最后一位是取四舍五入的结果的。比如在上面的代码中,若result = 3.2,那么输出就为 % p: ^7 e9 w4 B" W. R$ S; _8 w' T5 j
  The result is 3.
+ Y2 l; v" Y/ I+ t6 u2 @  若result = 3.5,那么输出则为 . D  X5 ^( w& j
  The result is 4. ; b6 u  h' W9 H; F+ O) {3 J
  把代码改为 ! v/ t7 R9 i  E: @1 ?, f9 \
  printf(\"The result is %.0f.\\n\", ceilf(result));
9 b( w. v3 r0 t# F9 G% a  问题就解决了(当然还要包含math.h头文件并使用g++编译器而不是gcc)。这么一个小小的问题,害我在一道超简单的题上提交了几乎10次(此题是北大acm网站上的1005题I Need a Houseboat),真是有点郁闷。不过还好没占用多长时间,何况也知道了一个细节性的知识(也算是知识吧),还算值得啦。
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

Archiver|手机版|小黑屋|Woexam.Com ( 湘ICP备18023104号 )

GMT+8, 2024-6-14 01:51 , Processed in 0.199476 second(s), 21 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

快速回复 返回顶部 返回列表