问答详情
源自:2-9 强制类型转换

如果我把int n 改成float n 是表达了什么呢?n的数据类型变成单精度了吗?如果是这样的话,输出得到的数值不会变才对,可是结果为什么变了

#include <stdio.h>

int main()

{

    double num = 2.5;

    int n = (int)num;//定义浮点型变量num并赋值为2.5

    printf("num的整数部分是%d\n", n);  

    return 0;

}


提问者:编集 2019-06-16 02:21

个回答

  • Lyke9883139
    2019-06-16 12:27:45
    已采纳

    float n是单精度的,如果你将int 改为float,强制类型转换这里也建议转换为float,之所以你的结果不对,是因为%d用错了,这里应该为%f.占位符用错了。

  • 编集
    2019-06-16 13:37:47

    受教了~灰常感谢大佬~~