/*
时间:2018.03.06 14:41
目的:1. 强制转化数据类型
2. 循环更新中的变量 i 规范使用中,不能定义为浮点型
*/
#include<stdio.h>
int main (void)
{
int i ; // 定义为 “float i;” 这里计算结果正确,但这种方法是错误
float sum = 0;
for (i=1; i<=100; ++i)
{
//sum = sum + 1/(float)i; // 强制将整型数据 “i” 转换为浮点型数据
sum = sum + 1.0/i; // 上个语句的另一种表达方式,推荐这种方式
}
printf (" sum = %f\n", sum);
return 0;
}
/*心得:
1.“ 1/i ” 整型与整型的运算结果依然为整型
2. float 类型的数据,不能保证所有的存储准确,如“0”,可能存的是“0.00001”
3. 因为2,所以循环中更新的变量不能定义为浮点型,如这里“i”增到100时,存储可能是“100.00001”,在判断是比100大,循环结束,而事实上“100”是符合条件的数
*/
强制数据类型转换
最新推荐文章于 2024-06-21 08:57:37 发布