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

为什么把double换成int输出值就为0.00了呢?

http://img1.sycdn.imooc.com//57e5cf9000014d1206450444.jpg

为什么把double换成int输出值就为0.00了呢?

正在回答

2 回答

//我觉得原本是double类型的cost精度那么高,非要转化为int型数据输出的时候肯定有问题,转换为二进制后cos//t这个内存数据可以很明显看出低32位全是0,而%d则只能截取到低32位,所以输出为0,然后在main函数中你再///以%lf输出,结果就会自动加上0.00了
#include<stdio.h>
int misska(int n,int m)
{
	float cost;
	if(n<3)
	{
		cost = 13;
	}
	else
	{
		if(m >= 23 || m < 5)
		{
			cost = 13 + (n-3)*2.3*1.2+1;
			//	printf("cost1:%d\n",cost);
		}
		else
		{
			cost = 13+(n-3)*2.3 + 1;
	printf("Cost by float:%lf\n",cost);
		}
	}
	printf("Cost by Integer:%d\n",cost);//这里可以看到转换成int输出后失真,直接变为一个负无穷数
	return cost;//这里返回的cost已经是一个int类型的,所以必定失真
}
int main()
{
		printf("Money1:%.2f\n",misska(12,9));//输出的类型确是%lf高精度型
		printf("Money2:%.2f\n",misska(12,18));//数据读取溢出,ide输出0.00
	printf("Money:%.2f\n",misska(12,9)+misska(12,18));
	
	return 0;
}

http://img1.sycdn.imooc.com//57e5ec090001a94211550683.jpg

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

一条被晒干的咸鱼 提问者

非常感谢!没发现有人回答了。。。抱歉喽
2016-09-24 回复 有任何疑惑可以回复我~

??明白了吗同学,你咋消失了

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

举报

0/150
提交
取消

为什么把double换成int输出值就为0.00了呢?

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