这是一个C语言输出函数的问题

问题描述:

#include<stdio.h>
#include<stdlib.h>

main()
{
float num=100;
float sum=0;
for(int i=0;i<10;i++)
{sum+=num;
num=num*(0.5);}
printf("%d",sum);
    system("pause");

return 0;
}

这个代码,当sum输出类型是%d的时候,输出为0.输出类型是%f的时候,输出198.5这是正确结果。我感觉输出类型为%d的时候,应该是199才对。把小数点后的四舍五入就行了。请问我想的,哪里有问题呢

printf("%d",(int)sum);
这样是199
如果你不加int强制转换,浮点数直接被当作整数输出,那结果就毫无意义了(在我的机器上输出-903014600,不是0)
得到199但是并不是因为四舍五入
由于精度误差的关系

#include<stdio.h>
#include<stdlib.h>

int main()
{
float num=100;
float sum=0;
for(int i=0;i<10;i++)
{sum+=num;
num=num*(0.5);}
printf("%f",sum);

return 0;
}

结果是 199.804688(注意,不同编译器甚至不同处理器,可能结果有微小的差异),所以是199,这是因为int是取整,不是四舍五入

要四舍五入可以
printf("%d",(int)(sum+0.5));

你思考的过程是没问题的,但你这个想法的前提(printf会自动类型转换)是彻彻底底的错的,很多人都容易在错误的前提下做大量正确的推导,因而觉得自己是完全对的而出问题的是代码或环境。
printf不会对变量类型进行自动转换,因为它是通过内存传变量的,在printf函数里根据%d或%f将内存转化为对应的格式,因此不会也不可能判断出来原来是什么类型,也就不会做自动类型转换以及达到你想要的效果。