C初学者在学到浮点型的时候,经常会有很多疑惑,下面是一些疑惑的解答:
首先,看下面的一个简单的程序
printf("%d",(3+3/4)*100);
很多初学者会认为结果是(3+0.75)*100=375
其实不然,结果应为300。
在C中,如果两个整型(int)变量做除法,如果出现了小数,那么,C只会取整数部分。
比如0.75,整数部分为0,小数部分为75,那么最终的结果应为0;
再比如1.25,最终结果应为1。
那么该如何解决这个问题?
第一种方法如下:
printf("%f",(3+3.0/4.0)*100);
把做除法的整数写成.0的形式,这就把整型变成了浮点型。下面的和这个类似:
printf("%f",(3+(double)3/(double)4)*100);
利用强制类型转换(在变量的前面用(括号里为要转换的类型)表示)
注意,这两种方法要把前面的%d改成%f,表示以浮点型输出。
第二种方法如下:
float a=3.0;
float b=4.0;
printf("%f",(a+a/b)*100);
声明两个浮点型变量,然后直接进行运算即可
注意,也可以写成如下的形式:
float a=3;
float b=4;
printf("%f",(a+a/b)*100);
因为在C中,整数加个.0即可看作浮点数,所以可以直接把整数的值赋给浮点型变量。(但最好不要这么写)
最后讨论一下关于 %n.mf的问题
先说明,n和m可以为任何正整数
那么n和m分别代表什么呢?
n代表你要输出多少个字符,但是如果n小于n=1,m=1(即%f)时输出的字符个数,则不会发生任何改变。
什么意思呢?先看一个程序:
printf("%f",1.125);
在我们的编译器上结果为1.125000,那么一共输出了8个字符(小数点也算一个字符,加上数字的七个一共八个)
如果0<n<=8,则在这个范围内,输出的结果不变
比如:
printf("%4f",1.125);
结果还是1.125000
如果n>8,则前面多了(n-8)个空格
比如:
printf("%10f",1.125);
结果为
1.125000
即
(空格)(空格)1.125000
那么m代表什么呢?
m代表输出的小数点的位数
如果n>6,则后面加(n-1)个0
比如:
printf("%.3f",1.125);
结果为1.125
表明小数点后从左到右最多输出3位
再比如:
printf("%8f",1.125);
结果为1.12500000
那么让我们把这两个综合一下,比如:
printf("%8.3f",1.125);
结果为
1.125
前面为3个空格。
为什么是这个结果呢,分析一下:
首先,%8.3f中的3表示小数点后为3位,加上前面的1和小数点一共是5位,8表示一共输出8个字符,而根据前面的分析,则需要在在前面填(8-5=3)个空格即可
至此,%n.mf问题对大家来说应该不是问题了