【C/C++】C/C++中int类型变量运算结果转float/double探究

本文通过一个C++示例详细解析了整数除法转换为浮点数的常见误区,强调了正确转换方法的重要性,避免精度损失。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在编程中,经常用到的一个结果转换就是两个int类型变量相除的结果为了保留精确度而转换为float或者double类型,但是这个地方最容易令人犯错误的是,如果使用如下的类型转换方式,转换时是将两个int类型变量先相除得到一个int类型结果,再将这个int类型结果转换为float或者double类型,而不是直接计算保留带有精确度的结果。

int main ()
{
	int x = 50;
	int y = 12;
	
	cout << x / y << endl;
	
	cout << (float) (x / y) << endl;			// 实际上并未达到预期效果
	
	cout << (double) (x / y) << endl;			// 实际上并未达到预期效果
	
	cout << (double) x / (double) y << endl;
	
	return 0;
}
4
4
4
4.16667
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值