C语言中的格式化打印 :
* 例如: printf("%.2f",21.195); 输出是 21.20 四舍五入保留了
* 定义宏变量 #define 即符号常量 也能够四舍五入保留
而变量和常变量 并不四舍五入:
float a=21.195 ; const float b=21.195; printf("%.2f \n %.2f",a,b); 输出为 21.19
并没有四舍五入,而是直接截断了
* 变量和常变量 不四舍五入
* 宏定义符号常量和实型常量 要四舍五入
今天做一个很简单的实验的时候,测试用例有一个一直有问题,便揣测应该是精度问题:
先看题目:
正常coding:
#include<stdio.h> #define PI 3.14 int main(void) { /*********Begin*********/
float r, h; //输入半径和高 scanf("%f,%f", &r, &h); float c, s, v; c = 2 * r * PI; s =
4*PI*r*r; v = PI*r*r*h; int x = round(v); printf("C1=%.2f\n", c); printf(
"Sb=%.2f\n", s); printf("Vb=%.2f\n", v); /*********End**********/ return 0; }
然后发现测试有问题:
题目要求通过的是 最后一个 Vb体积为 21.20 而PI是确定的3.14
那问题出在哪了呢?
于是我便不保留2位输出 把 “%.2f” 换为 “%f”
所以可知 C语言中的 格式化打印 %.2f 保留两位 对于变量和常变量 是直接割舍的 不是四舍五入
测试了Java的格式化输出 Java中的是四舍五入的
可以看到 Java中不管是实型常量、常变量还是变量输出都是四舍五入的
那要怎么解决四舍五入保留小数呢?
* 方案一:
在计算体积的时候采用:添加这样一个方法来
v=(int)(v*100+0.5)/100.0;
* 先将体积扩大100倍,
* +0.5再把float类型强转为int类型即可达到四舍五入的效果,
* 再除以100.0浮点数又自动转为浮点类型 #include<stdio.h> #include<math.h> #define PI 3.14 int
main(void) { /*********Begin*********/ float r, h; scanf("%f,%f", &r, &h); float
c, s, v; c = 2 * r * PI; s = 4*PI*r*r; v = PI*r*r*h; v=(int)(v*100+0.5)/100.0;
int x = round(v); printf("C1=%.2f\n", c); printf("Sb=%.2f\n", s); printf(
"Vb=%.2f\n", v); /*********End**********/ return 0; }
* 方案二: #include<math.h> 里提供了这么一个方法: round() 用例: float a=3.1415926; float b=
round(a); 可得到 b=3
所以还是和方案一的思路一样
加一个:
v=round(v*10)/10.0;
即可,效果一样
总结一下,C语言中的格式化打印输出,对于实型常量和符号常量是能够四舍五入保留的,但对于变量和常变量却不行,但自己处理。