https://www.imooc.com/qadetail/168807
![http://img.mukewang.com/57e5cf9000014d1206450444.jpg](https://i-blog.csdnimg.cn/blog_migrate/48e85368951a9cb903bfbc2c5e916102.png)
//我觉得原本是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://img.mukewang.com/57e5ec090001a94211550683.jpg](https://i-blog.csdnimg.cn/blog_migrate/95c1539f7e307ccc59a3e7192333d3c9.png)