问答详情
源自:5-14 综合练习

为什么运行结果小数末位是.00001?

#include <stdio.h>
extern float getFee(float Num, float Clk)
{
	float Fee=0;
	if ((Clk >= 23 && Clk <= 24) || (Clk <= 5 && Clk >= 0))
	{
		if (Num>3)
		{
			Fee = 13 + 2.3*1.2*(Num - 3) + 1;
			return Fee;
		}
		else
			return 13 + 1;
	}
	else
	{
		if (Num>3)
		{
			Fee = 13 + 2.3*(Num - 3) + 1;
			return Fee;
		}
		else
			return 13 + 1;
	}

}
int main()
{
	printf("小明早上打车花费%f元\n", getFee(12, 9));
	printf("小明晚上打车花费%f元\n", getFee(12, 18));
	printf("小明每天打车费用为%f元\n", getFee(12, 9) + getFee(12, 18));
	return 0;
}


提问者:Dickson_zhai 2017-09-13 22:04

个回答

  • xhm_hm
    2017-09-14 14:07:08
    已采纳

    printf的格式控制的完整格式: 

    % - 0 m.n l或h 格式字符  

    下面对组成格式说明的各项加以说明:

    ①%:表示格式说明的起始符号,不可缺少。 

    ②-:有-表示左对齐输出,如省略表示右对齐输出。 

    ③0:有0表示指定空位填0,如省略表示指定空位不填。 

    ④m.n:m指域宽,即对应的输出项在输出设备上所占的字符数。N指精度。用于说明输出的实型数的小数位数。未指定n时,隐含的精度为n=6位。 

    ⑤l或h:l对整型指long型,对实型指double型。h用于将整型的格式字符修正为short型。

     
    格式字符  

    格式字符用以指定输出项的数据类型和输出格式。 

    ①d格式:用来输出十进制整数。有以下几种用法: 

    %d:按整型数据的实际长度输出。 

    %md:m为指定的输出字段的宽度。如果数据的位数小于m,则左端补以空格,若大于m,则按实际位数输出。 

    %ld:输出长整型数据。 

    ②o格式:以无符号八进制形式输出整数。对长整型可以用"%lo"格式输出。同样也可以指定字段宽度用“%mo”格式输出。 

    float格式同理


  • qq_雪沙滩_03946525
    2017-09-14 11:32:58

    float类型小数点后面6位小数,所以会是0.000001;这里输出应该定义为%.1f