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文件。能在程式的开始添加如下代码: #include <math.h> |
|