C/C++取整函数

来源:互联网 发布:matlab矩阵diag 编辑:程序博客网 时间:2024/04/29 21:32

ceil()—取整函数(取不小于参数的最小整型数)

相关函数:fabs

头文件:#include <math.h>

定义函数:double ceil (double x);

函数说明:ceil()会返回不小于参数x 的最小整数值, 结果以double 形态返回.

返回值:返回不小于参数x 的最小整数值.

附加说明:使用 GCC 编译时请加入-lm.

范例
#include <math.h>
main()
{
    double value[] = {4.8, 1.12, -2.2, 0};
    int i;
    for (i = 0; value[i] != 0; i++)
    printf("%f=>%f\n", value[i], ceil(value[i]));
}

执行
4.800000=>5.000000
1.120000=>2.000000
-2.200000=>-2.000000

C/C++取整函数ceil(),floor()

使用floor函数。floor(x)返回的是小于或等于x的最大整数。
如:     floor(10.5) == 10    floor(-10.5) == -11


使用ceil函数。ceil(x)返回的是大于x的最小整数。
如:     ceil(10.5) == 11    ceil(-10.5) ==-10

    
floor()是向负无穷大舍入,floor(-10.5) == -11;
ceil()是向正无穷大舍入,ceil(-10.5) == -10

 

fix
朝零方向取整,如fix(-1.3)=-1; fix(1.3)=1;
floor
朝负无穷方向取整,如floor(-1.3)=-2; floor(1.3)=1;
ceil
朝正无穷方向取整,如ceil(-1.3)=-1; ceil(1.3)=2;
round
四舍五入到最近的整数,如round(-1.3)=-1;round(-1.52)=-2;round(1.3)=1;round(1.52)=2


C语言有以下几种取整方法: 
    1、直接赋值给整数变量。如: 
    int i = 2.5; 或 i = (int) 2.5; 
    这种方法采用的是舍去小数部分,能用于你的问题。 
    2、C/C++中的整数除法运算符“/”本身就有取整功能(int / int),而下面介绍的取整函数返回值是double。整数除法对正数的取整是舍去小数部分,能用于你的问题。不过整数除法对负数的取整结果和使用的C编译器有关。 
    3、使用floor函数。floor(x)返回的是小于或等于x的最大整数。如: 
    floor(2.5) = 2 
    floor(-2.5) = -3 
    4、使用ceil函数。ceil(x)返回的是大于x的最小整数。如: 
    ceil(2.5) = 3 
    ceil(-2.5) = -2 
    floor()是向负无穷大舍入,floor(-2.5) = -3;ceil()是向正无穷大舍入,ceil(-2.5) = -2。floor函数能用于你的问题。 
     
    hyh的意见: 
    int x,a,b,c,d; 
    a=x/1000; 
    b=x%1000/100; 
    c=x%100/10; 
    d=x%10; 
     
    郭丽: 几位专家解释的floor和ceil两个函数是不是只能在 tc 2.0中适用,我在vc++中试过了,不认这个函数,是不是还要包括一个什么特别的头文件啊?请各位专家指教,我是新手。谢谢了 
    :这两个函数在VC++中也能使用,但使用时需要包含math.h文件。能在程式的开始添加如下代码: 


原创粉丝点击