让你彻底明白c语言的浮点型及整型除法问题

您所在的位置:网站首页 取整符号c语言 让你彻底明白c语言的浮点型及整型除法问题

让你彻底明白c语言的浮点型及整型除法问题

2023-08-26 09:50| 来源: 网络整理| 查看: 265

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