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

来源:计算机等级考试    发布时间:2012-08-28    计算机等级考试视频    评论

 今日在做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),真是有点郁闷。不过还好没占用多长时间,何况也知道了一个细节性的知识(也算是知识吧),还算值得啦。

视频学习

我考网版权与免责声明

① 凡本网注明稿件来源为"原创"的所有文字、图片和音视频稿件,版权均属本网所有。任何媒体、网站或个人转载、链接转贴或以其他方式复制发表时必须注明"稿件来源:我考网",违者本网将依法追究责任;

② 本网部分稿件来源于网络,任何单位或个人认为我考网发布的内容可能涉嫌侵犯其合法权益,应该及时向我考网书面反馈,并提供身份证明、权属证明及详细侵权情况证明,我考网在收到上述法律文件后,将会尽快移除被控侵权内容。

最近更新

社区交流

考试问答