为了账号安全,请及时绑定邮箱和手机立即绑定

为什么运行结果小数末位是.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;
}


正在回答

2 回答

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格式同理


0 回复 有任何疑惑可以回复我~
#1

Dickson_zhai 提问者

非常感谢!
2017-09-16 回复 有任何疑惑可以回复我~

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

0 回复 有任何疑惑可以回复我~

举报

0/150
提交
取消

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

我要回答 关注问题
意见反馈 帮助中心 APP下载
官方微信