让你彻底明白c语言的浮点型及整型除法问题 |
您所在的位置:网站首页 › 除法怎么样算 › 让你彻底明白c语言的浮点型及整型除法问题 |
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个字符(小数点也算一个字符,加上数字的七个一共八个) 如果06,则后面加(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问题对大家来说应该不是问题了 |
CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3 |