为了账号安全,请及时绑定邮箱和手机立即绑定

如果我把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;

}


正在回答

2 回答

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

1 回复 有任何疑惑可以回复我~
#1

编集 提问者

灰常感谢~~
2019-06-16 回复 有任何疑惑可以回复我~

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

0 回复 有任何疑惑可以回复我~

举报

0/150
提交
取消

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

我要回答 关注问题
意见反馈 帮助中心 APP下载
官方微信