我有一个浮点数组,其中数据以不同的小数点存储,因此有些是123.40000
,123.45000
,123.45600
...现在,如果我想在这些值中打印这些值printf()
中最后没有0的字符串,因此它们是123.4
,123.45
,123.456
,最后没有那些0。这可能吗?如果是这样,怎么样?
答案 0 :(得分:18)
使用%g格式化程序:
printf( "%g", 123.4000 );
打印
123.4
删除尾随零,但不幸的是,如果小数部分为零,则尾随小数点也是如此。我不知道是否有任何方法可以直接使用printf()做你想做的事情 - 我觉得这样的事情可能是你最好的选择:
#include <stdio.h>
#include <math.h>
void print( FILE * f, double d ) {
if ( d - floor(d) == 0.0 ) {
fprintf( f, "%g.", d );
}
else {
fprintf( f, "%g", d );
}
}
int main() {
print( stdout, 12.0 );
print( stdout, 12.300 );
}
答案 1 :(得分:3)
我不知道这有多酷,但是:
float f = 124.000;
if (f == (int) f) {
printf("%.1f\n", f); /* .1 can be changed */
} else {
printf("%g\n", f);
}
返回124.0
。
float f = 124.123000;
if (f == (int) f) {
printf("%.1f\n", f); /* .1 can be changed */
} else {
printf("%g\n", f);
}
返回124.123
。
答案 2 :(得分:0)
使用%g -
以正常或指数表示法打印双精度,以其大小为准。 'g'使用小写字母,'G'使用大写字母。此类型与定点表示法略有不同,因为不包括小数点右侧的无效零。此外,小数点不包括在整数中。
答案 3 :(得分:0)
打印到(足够大)缓冲区。打印缓冲区...如果缓冲区中没有'.'
,则打印一个点。
char buf[100];
sprintf(buf, "%g", val);
printf("%s", buf);
if (strchr(buf, '.') == NULL) putchar('.');
修改的
标准指定#
标志:
#结果转换为“替代形式”。 [...] a,A, e,E,f,F,g和G转换,转换浮点的结果 number始终包含小数点字符,即使后面没有数字也是如此 它。 [...]对于g和G转换,不会删除尾随零 结果。 [...]
...但你得到的是尾随零:(