转换声明%g和%G的输出
01、%g和%G的使用说明
在书籍 《C primer Plus》 中4.4节有提到printf函数的“转化说明”,比如常用的整型输出转化说明:%d,可以用来输出一个整型。
#include<stdio.h>
int main()
{
int n=2;
printf("%d",n);
return 0;
}
然后对于“转化说明”%g和%G的描述是这样的:
转化说明 | 输出 |
---|---|
%g | 根据值的不同,自动选择%f或%e,%e格式用于指数小于-4或者大于或等于精度时 |
%G | 根据值的不同,自动选择%f或%E,%E格式用于指数小于-4或者大于或等于精度时 |
简单来说,当一个浮点数转为指数计数法时:
- ①指数>=6或者<-4的时候:%g(%G)选择 %e(%E)输出
- ②指数其余情况:都是选择%f输出
指数计数法:比如20表示为0.2 * 102 就是使用指数计数法计数,其中10上面的“2”就是0.2 * 102 的指数。
而%g和%G的区别仅仅是输出指数表达式的时候,10时写成e还是E,两者几乎没有用区别。
02、废话不多说直接上代码
#include<stdio.h>
int main()
{
//指数>=6
double a, b, c, d;
double e, f, g, h;
a = 12345678;
b = 1234567;
c = 123456;
d = 12345;
printf("①指数>=6或者<-4的时候:%%g(%%G)选择 %%e(%%E)输出\n"
"②其余情况:都是选择%%f输出\n\n");
printf("指数>=6的时候\n");
printf("%%f\t\t %%e\t\t %%g\t\t %%G\n");
printf("%f\t %e\t %g\t %G\n", a, a, a, a);
printf("%f\t %e\t %g\t %G\n", b, b, b, b);
printf("%f\t %e\t %g\t %G\n", c, c, c, c);
printf("%f\t %e\t %g\t\t %G\n", d, d, d, d);
printf("\n");
//指数<=-4
e = 0.000001;
f = 0.00001;
g = 0.0001;
h = 0.001;
printf("指数<=-4的时候\n");
printf("%%f\t\t %%e\t\t %%g\t\t %%G\n");
printf("%f\t %e\t %g\t\t %G\n", e, e, e, e);
printf("%f\t %e\t %g\t\t %G\n", f, f, f, f);
printf("%f\t %e\t %g\t %G\n", g, g, g, g);
printf("%f\t %e\t %g\t\t %G\n", h, h, h, h);
return 0;
}
程序结果为:
另外还可以注意到%g(%G)在选择%f输出的时候,是不会有多余的0出现的。例如:本代码的结果中,前面的%f输出还是12345.000000,后面的%g(%G)仅仅输出了12345
而防止多余的0被删除的方法就是在%后面加上修饰符#。