c语言取四舍五入
① c语言四舍五入是怎样的
全舍不入
需要实现四舍五入的时候就要使用double或者float类型的数进行运算然后if判断
http://..com/question/68502540.html刚好有个类似的问题
② c语言中有没有四舍五入的函数
double ceil(double x)返回不小于x的最小整数值(然后转换为double型)。
double floor(double x)返回不大于x的最大整数值。
double round(double x)返回x的四舍五入整数值
int abs(int) 返回整数绝对值
double fabs(double) 返回浮点数绝对值
③ C语言怎么四舍五入
利用取整。
比如 四舍五入到千分位,可以
(int)(x*1000+0.5)/1000.0
十分位(int)(x*10+0.5)/10.0
其他类似,只改变其中倍数的值即可。
④ c语言 四舍五入
# incloud <stdio>
int main(void)
{
float a ;
scanf(“%f”,&a);
a=(int)(a*1000+0.5)/1000.0;
printf (“%0.3f”,a);
return 0;
}
(4)c语言取四舍五入扩展阅读:
其他方法实现四舍五入:
int myround(double indata,int precision,double * outdata)
{
long pre = 1,i;
for(i = 0; i <precision; i ++)pre = pre * 10;
if(cy_FloatCompare(indata,0.00)> 0)
* outdata =(int)((indata * pre)+0.5)/100.00;
else
* outdata =(int)((indata * pre)-0.5)/100.00;
return 0;
}
// cy_FloatCompare是浮点数与0比较的函数,假设它存在。返回值与strcmp相同。
⑤ c语言四舍五入
#include<stdio.h>
main()
{
double a;
printf("清输入一个小数 ");
scanf("%lf",&a);
a=(int)(a*100+0.5);
a=a/100;
printf("输出的四舍五入结果是 %.2f",a);
}
这样就对了,输入格式有错
⑥ c语言中如何进行四舍五入,求详细解释!!谢谢!
方法一:
#include<stdio.h>
int main()
{
double d1,d2,d3;
d1=-3.1415926;
d2=(int)(d1*10+0.5)*0.1;
printf("d1=%f,保留一位小数的结果为:%.1f ",d1,d2);
d3=(int)(d1*1000+0.5)*0.001;
printf("d1=%f,保留三位小数的结果为:%.3f",d1,d3);
总结四舍五入保留n为小数
(int)(x*10的n次方+0.5)*10的负n次方;
其次这个方法对负数无效;如果非要用可以先取正数部分算,最后加上负号
}
方法二:
使用round()函数。
#include"stdio.h"
#include"math.h"
void main()
{
float x;
scanf("%f",&x);
int y = round(x);
printf("%d",y);
}
(6)c语言取四舍五入扩展阅读:
C语言编写注意事项:
1、%运算符不能应用与float或double类型。
2、char类型转换为int型时, 无法判断它是signed还是unsigned.这样其结果有可能为负数, 因此转换时尽量指定signed和unsigned限制符。
3、++i与i++不同之处: ++i是先+1在使用, i++是先使用i在递加1。
4、三元运算符"?:" 第一个表达式的括号不是必须的,但是由于三元表达式的优先级非常低,我们还是将第一个表达式用()括起便于阅读和理解。
5、C语言中可以使用递归 (即函数调用自身函数), 其不节省储存器开销也不加快执行速度, 只是使程序紧凑便于理解。
⑦ C语言问题,这里怎么实现四舍五入的啊
假定一个数字x值是10.456,那么保留两位,第三位四舍五入的方法就是先将x乘以100,变成1045.6,然后加上0.5,得到1046.1,然后去除1046.1的小数部分(也就是强制转为int),得到1046,再用1046除以100.0就得到最终的10.46,写出来也就是
x=(int)(x*100+0.5)/100.0