printf()中的浮点格式

时间:2009-12-07 23:22:11

标签: c floating-point floating-accuracy

我有一个浮点数组,其中数据以不同的小数点存储,因此有些是123.40000123.45000123.45600 ...现在,如果我想在这些值中打印这些值printf()中最后没有0的字符串,因此它们是123.4123.45123.456,最后没有那些0。这可能吗?如果是这样,怎么样?

4 个答案:

答案 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)

我不知道这有多酷,但是:

http://codepad.org/e3Q3pUNd

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转换,不会删除尾随零   结果。 [...]

...但你得到的是尾随零:(