本文编程学习网主要和大家介绍用C语言如何四舍五入保留一位小数,通过具体的代码向大家展示,希望对大家学习C语言编程入门有所帮助。
方法1:编程实现
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 <stdio.h>
int main(void) {
float a;
scanf("%f", &a);
a = (int)(a*1000+0.5)/1000.0;
printf("%0.3f", a);
return 0;
}
方法2:库函数实现
C99标准以后,有一个round函数可以直接调用,
round(x)
参数时double型,返回小数对整数部分的四舍五入值
比如 round(3.623); 返回4
C语言中保留两位小数:小技巧
①
float a = 3.456; //保留到小数点后两位
float b =(int)((a * 100) + 0.5) / 100.0;
输出结果为3.46
精度比较高
②
float a = 23.456789;
printf(“%.2f”,a); //输出为23.45
#include"stdio.h"
#include"math.h"
void main()
{
float x;
scanf("%f",&x);
int y = round(x);
printf("%d",y);
}
以上就是“c语言如何四舍五入保留一位小数”的详细内容,想要了解更多C语言教程欢迎持续关注编程学习网!
扫码二维码 获取免费视频学习资料
- 本文固定链接: http://phpxs.com/post/10635/
- 转载请注明:转载必须在正文中标注并保留原文链接
- 扫码: 扫上方二维码获取免费视频资料
查 看2022高级编程视频教程免费获取