C++中double型数据怎么取整数部分,就是小数后面全变成0。

需要注意的是double的整数部分超出了int的表示范围。
不要回答double a ; a=(int)a; 的答案,我试过不行的。

1、首先,定义一个double型变量n,保存取整的数值。

2、用ceil函数对实数5.78取整,取整后的数值保存在变量n中。

3、输出取整后的数值n。

4、运行程序,输出的值为6,这是因为ceil是对实数向上取整。

5、接着,将ceil内的数更改为5.18。

6、运行程序,看到的结果还是6,说明ceil是向上取整。

温馨提示:答案为网友推荐,仅供参考
第1个回答  推荐于2017-10-10

    方法一:使用强制类型转换,强制舍去小数部分。

    例如 double a=3.14; int b= (int)a;

    方法二:使用math.h的标准函数。

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

第2个回答  推荐于2017-10-07
floor(x)是向下取整函数,如果是负数的话,这个函数就不对了
double ceil( double x ); 向0取整,应该用这个
头文件#include <math.h>本回答被提问者采纳
第3个回答  2012-08-18
void main()
{
double a = 345.3853;
double b = 0;
b = (double)(int)a;
printf("\n%lf",b);
}追问

叫你别答这个了,真心没用。超出了int表示的范围是不行的。不要很大就32768就不行。

追答

b=(double)(long int)a;

本回答被网友采纳
第4个回答  2012-08-18
floor(x)专门的取整函数追问

能问一个,这个函数是在哪个头文件里吗?

相似回答