C语言实现小数四舍五入 |
您所在的位置:网站首页 › c语言保留整数四舍五入 › C语言实现小数四舍五入 |
做日记笔记。 转载自https://blog.csdn.net/weixin_38505045/article/details/79994536 排版有更改 C语言中实现四舍五入: (int)(a+0.5)即可。 很巧妙的用了取整规则。 也不用导入math.h 同样注意负数的情况。 把 + 换成 - 即可。 float f = ……; int i = (int)(f + 0.5); i就是f四舍五入的结果。 今天我要介绍在C语言中实现数据四舍五入的算法。 我们知道,C语言中去除小数位采用的方法就是强制性转化成整型类型。那么假如我们要对一个小数保留三个小数位,而第四个小数位按照四舍五入的规则进行, 该怎样实现呢? 很简单,我们将数字扩大1000倍,使得第四位小数称为新数字的第一位,然后我们可以给它加上0.5后再进行强制性转化。 加0.5的原因就是: 假如这个小数位的数值大于5,加上0.5能够实现进位的作用,倘若小于0.5,就没有实现进位的作用。如此,就能实现小数位的四舍五入。然后我们再对这个数值 进行强制性转化,然后再处以1000.0(记住,一定要1000.0,否则就会出现隐式转化),在输出的时候用%0.3f以实现保留三位小数。 # include int main(void) { float a; scanf("%f", &a); a = (int)(a*1000+0.5)/1000.0; printf("%0.3f", a); return 0; }C语言中保留两位小数:小技巧 1、 float a = 3.456; //保留到小数点后两位 float b =(int)((a * 100) + 0.5) / 100.0; 输出结果为3.46 精度比较高 2、 float a = 23.456789; printf(“%.2f”,a); //输出为23.45 3、 有一个round函数可以直接调用, round(x) 参数是double型,返回小数对整数部分的四舍五入值 比如 round(3.623); 返回4 #include"stdio.h" #include"math.h" void main() { float x; scanf("%f",&x); int y = round(x); printf("%d",y); } |
今日新闻 |
推荐新闻 |
CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3 |