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

来源:2-9 强制类型转换

编集

2019-06-16 02:21

#include <stdio.h>

int main()

{

    double num = 2.5;

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

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

    return 0;

}


写回答 关注

2回答

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

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

    编集

    灰常感谢~~

    2019-06-16 13:39:23

    共 1 条回复 >

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

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

C语言入门

C语言入门视频教程,带你进入编程世界的必修课-C语言

926212 学习 · 20797 问题

查看课程

相似问题