码迷,mamicode.com
首页 > 编程语言 > 详细

C语言取整方法总结

时间:2015-07-21 18:37:41      阅读:586      评论:0      收藏:0      [点我收藏+]

标签:c语言   向上取整   向下取整   

C语言有以下几种取整方法:

1.   直接赋值给整数变量

    int i = 3.5; 或 i = (int) 3.5;

    这种方法采用的是舍去小数部分。

2、整数除法运算符‘ / ’取整

    ‘ / ’本身就有取整功能(int / int),但是整数除法对负数的取整结果和使用的C编译器有关。

3、使用floor函数

    floor(x)返回的是小于或等于x的最大整数。如:

    floor(3.5) = 3

    floor(-3.5) = -4

4、使用ceil函数

    ceil(x)返回的是大于x的最小整数。如:

    ceil(3.5) = 4

    ceil(-3.5) = -3

    floor()是向负无穷大舍入,floor(-3.5)  = -4;

    ceil()是向正无穷大舍入,ceil(-3.5)  = -3。

    但是在C里面ceil和floor()函数是返回double

5.向上取整方法

    在网上发现一个简单的向上取整方法;

    这里我们用<>表示向上取整,[]表示向下取整,我们可以证明:

    <N/M>= [(N-1)/M]+1    (0 < M <= N   M,N∈Z)

     不失一般性,我们设N = Mk+r (0 <= r < M,k∈Z),

(1)当r > 0时,

    左边:<N/M> = <(Mk+r)/M >= <k+r/M>= k+<r/M> = k+1

    右边:[(N-1)/M]+1 = [(Mk+r-1)/M]+1 = [k+(r-1)/M]+1 = k+1+[(r-1)/M]=k+1

(2)当r = 0时,

    左边:<N/M> = k

    右边:

    [(N-1)/M]+1 = [(Mk-1)/M]+1 = [(M(k-1)+M-1)/M]+1

    = [k-1+(M-1)/M]+1 = k+[(M-1)/M]

    = k

    综上,命题得证。

    有了这个公式,我们在代码里可以这样计算:

    int nn = (N-1)/M +1

    式中‘ / ‘是往下取整的。


版权声明:本文为博主原创文章,未经博主允许不得转载。

C语言取整方法总结

标签:c语言   向上取整   向下取整   

原文地址:http://blog.csdn.net/solomon1558/article/details/46989415

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!