强制类型转换

例如:

#include <stdio.h>
int main()
{  int a,b;
   float c;
   a=3;
   b=2;
   c=a/b;
   printf("%f",c);//输出结果1.000000
   return 0;
}

这是因为a和b的类型都是int,所以运算结果c也会转换为int型(即舍去小数),a/b = 1,之后再将取整后的数据(即整数1)转换为float类型(即1.000000)赋值给变量c,所以最后输出1.000000

订正:

#include <stdio.h>
int main()
{  int a,b;
   float c;
   a=3;
   b=2;
   c=(float)a/b;//c=a/(float)b或c=(float)a/(float)b皆可
                //不可写作c=(float)(a/b);这样(float)(5/2)=2.0
   printf("%.2f",c);//输出1.50
   return 0;
}

备注:
1.a,b一开始也定义成float,就不用强制类型转换了。
2.如果是混合运算,比如c=a/b+32,还是将a或b进行强制类型转换,即使最先的运算结果就要精确。又若如c=3*a/b+32,可写作c=3.*a/b+32。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值