1.取整,返回值为int:
double a = 123.456;
int b = (int)a;//取整
int c = (int)(a+0.5);//四舍五入
C99里的round应该可以做到四舍五入
#include
double
round(double x);
---------------------------------------------------------------------------------------------------------------------------------
问题是当你的9多过double表示的有效数字位后,编译器已经把这个数解释为9.50了.
或者说我的精度要求是10个9或8个9,后面还有数字,则我都可以把它看成9.50了.
double数本来就不可以绝对精确.
-----------------------------------------------------------------------------------------------------------------------------------
在turbo c中 double 有效数字是15~16位
2、C/C++中的整数除法运算符“/”本身就有取整功能(int / int),而下面介绍的取整函数返回值是double。整数除法对正数的取整是舍去小数部分,可以用于你的问题。但是整数除法对负数的取整结果和使用的C编译器有关。
3、使用floor函数。floor(x)返回的是x的整数部分。如:
函数名: floor
功 能: 向下舍入
用 法: double floor(double x);
floor(2.5) = 2
floor(-2.5) = -3
4、使用ceil函数。ceil(x)返回的是不大于x的最小整数。如:
函数名: ceil
功 能: 向上舍入
用 法: double ceil(double x);
ceil(2.5) = 3
ceil(-2.5) = -2
floor和ceil对于正数没有区别,但是对于负数结果不同。floor()是向负无穷大舍入,floor(2.5) = 2,floor(-2.5) = -3;ceil()是向正无穷大舍入,ceil(2.5) = 3,ceil(-2.5) = -2。
阅读(1891) | 评论(0) | 转发(0) |