文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

聊聊几个小数取整函数的问题

2024-12-03 04:21

关注

在c++的cmath库中提供了几个小数取整的函数ceil() floor() round() trunc,我们可以根据不同的场景去选用它们。

下面我们依次来看看这几个函数的特性。

ceil函数

ceil函数如下定义,函数返回不小于参数arg的最小整数,即向上取整。

  1. float ceil ( float arg ); 
  2. double ceil ( double arg ); 

我们可以用下图来直观的描述它,空心表示横坐标Arg不包含所在点的值,实心表示包含所在点的值。

ceil函数

一个例子:

  1. #include  
  2. #include  
  3. int main() 
  4.     // ceil 
  5.     std::cout << "ceil(+3.3) = " << std::ceil(+3.3) << '\n' 
  6.               << "ceil(-3.4) = " << std::ceil(-3.4) << '\n' 
  7.               << "ceil(-0.0) = " << std::ceil(-0.0) << '\n' 
  8.               << "ceil(-Inf) = " << std::ceil(-INFINITY) << '\n'

结果如下:

  1. ceil(+3.3) = 4 
  2. ceil(-3.4) = -3 
  3. ceil(-0.0) = -0 
  4. ceil(-Inf) = -inf 

floor函数

floor函数如下定义,函数返回不大于arg的最大整数值,即向下取整。

  1. float floor ( float arg ); 
  2. double floor ( double arg ); 

其取值方法我们可以看下图:

floor函数

再看代码:

  1. #include  
  2. #include  
  3. int main() 
  4.     // floor 
  5.     std::cout << "floor(+3.6) = " << std::floor(+3.6) << '\n' 
  6.               << "floor(-3.2) = " << std::floor(-3.2) << '\n' 
  7.               << "floor(-0.0) = " << std::floor(-0.0) << '\n' 
  8.               << "floor(-Inf) = " << std::floor(-INFINITY) << '\n'

结果:

  1. floor(+3.6) = 3 
  2. floor(-3.2) = -4 
  3. floor(-0.0) = -0 
  4. floor(-Inf) = -inf 

round函数

round函数是我们最常用的取整方式,通过四舍五入方式取整,其定义如下:

  1. float round ( float arg ); 
  2. double round ( double arg ); 

同样的我们可以用图来描述它:

round

代码也要有:

  1. #include  
  2. #include  
  3.  
  4. int main() 
  5.     // round 
  6.     std::cout << "round(+4.2) = " << std::round(4.2)  << '\n' 
  7.               << "round(+4.5) = " << std::round(4.5)  << '\n' 
  8.               << "round(+4.7) = " << std::round(4.7)  << '\n' 
  9.               << "round(-4.3) = " << std::round(-4.3) << '\n' 
  10.               << "round(-4.5) = " << std::round(-4.5) << '\n' 
  11.               << "round(-4.8) = " << std::round(-4.8) << '\n'
  12.   

看结果啦~

  1. round(+4.2) = 4 
  2. round(+4.5) = 5 
  3. round(+4.7) = 5 
  4. round(-4.3) = -4 
  5. round(-4.5) = -5 
  6. round(-4.8) = -5 

trunc函数

除了上面几个取整方式之外,还有另外一个取整方式,我们可以叫“舍尾取整”,实际上它的作用是将整数和小数部分截断。

  1. float trunc ( float arg ); 
  2. double trunc ( double arg ); 

从图上可以看出,这个函数的作用是将整数部分保留而舍去小数部分。

图片看示例:

  1. #include  
  2. #include  
  3. int main() 
  4.     // trunc 
  5.     std::cout << "trunc(+2.7) = " << std::trunc(+2.7) << '\n' 
  6.               << "trunc(-2.9) = " << std::trunc(-2.9) << '\n' 
  7.               << "trunc(-0.0) = " << std::trunc(-0.0) << '\n' 
  8.               << "trunc(-Inf) = " << std::trunc(-INFINITY) << '\n'

结果如下:

  1. trunc(+2.7) = 2 
  2. trunc(-2.9) = -2 
  3. trunc(-0.0) = -0 
  4. trunc(-Inf) = -inf 

最后

以上就是c++中提供的几个取整函数的说明和使用方法,我们一定要熟知其特性而选择正确的函数,在大量的数据运算中,使用不同的函数进行取整,最终的运算结果往往会有着很大的差异。

本文转载自微信公众号「Will的大食堂」,可以通过以下二维码关注。转载本文请联系Will的大食堂公众号。

 

来源:Will的大食堂内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯