#include <stdio.h>
#include <math.h>
int main(){
double num_1=0.555,num_2=1.555,num_3=2.555,num_4=3.555;
printf("%.2f\n",num_1);
printf("%.2f\n",num_2);
printf("%.2f\n",num_3);
printf("%.2f\n",num_4);
return 0;
}
输出:
0.56
1.55
2.56
3.56
有一个没有四舍五入,说明编译器并不会自动实现四舍五入的。
但我们知道,浮点数赋给一个整数变量后,一定不会四舍五入
#include <stdio.h>
#include <math.h>
int main(){
double num_1=0.555,num_2=1.555,num_3=2.555,num_4=3.555;
int num_1_1=num_1;
int num_2_2=num_2;
int num_3_3=num_3;
int num_4_4=num_4;
printf("%d\n",num_1_1);
printf("%d\n",num_2_2);
printf("%d\n",num_3_3);
printf("%d\n",num_4_4);
return 0;
}
输出:
0
1
2
3
为了解决四舍五入的问题,提出了三个方法
方法一:使用库函数 #include <math.h>
此方法只适用于四舍五入取整
#include <stdio.h>
#include <math.h>
int main(){
double num_1=0.555,num_2=1.555,num_3=2.455,num_4=3.655;
int num_1_1=round(num_1);
int num_2_2=round(num_2);
int num_3_3=round(num_3);
int num_4_4=round(num_4);
printf("%d\n",num_1_1);
printf("%d\n",num_2_2);
printf("%d\n",num_3_3);
printf("%d\n",num_4_4);
return 0;
}
输出:
1
2
2
4
方法二:加0.5法
此方法只适用于四舍五入取整
#include <stdio.h>
#include <math.h>
//当一个数为1.555,加上0.5,变成2.055.如一个数为2.455,加上0.5,变为2.955.这时候取整,这正好符合我们四舍五入的要求。
int main(){
double num_1=0.555,num_2=1.555,num_3=2.455,num_4=3.655;
int num_1_1=num_1+0.5;
int num_2_2=num_2+0.5;
int num_3_3=num_3+0.5;
int num_4_4=num_4+0.5;
printf("%d\n",num_1_1);
printf("%d\n",num_2_2);
printf("%d\n",num_3_3);
printf("%d\n",num_4_4);
return 0;
}
输出:
1
2
2
4
方法三:强制转换 PS:强制转换优先级比自加自减靠前
#include <stdio.h>
#include <math.h>
//当一个数为1.555,加上0.5,变成2.055.如一个数为2.455,加上0.5,变为2.955.这时候取整,这正好符合我们四舍五入的要求。
int main(){
double num_1=0.557,num_2=1.555,num_3=2.455,num_4=3.655;
double num_1_1=(int)(num_1*100+0.5)*1.0/100; //四舍五入至小数点后二位
double num_2_2=(int)(num_2*10+0.5)*1.0/10; //四舍五入至小数点后一位
double num_3_3=(int)(num_3+0.5); //四舍五入至整数
double num_4_4=num_4+0.5;
printf("%f\n",num_1_1);
printf("%f\n",num_2_2);
printf("%f\n",num_3_3);
printf("%f\n",num_4_4);
return 0;
}
输出:
0.560000
1.600000
2.000000
4.155000