/*********************
2011年9月4日11:41:27
目的:求1+1/2+1/3+......+1/100
**************************/
#include<stdio.h>
int main(void)
{
int i;
float j;
float sum = 0;
for(i=1;i<=100;i++)
{
// j=1/i; 假如程序這樣執行的話 依然結果是不對的
// j=1.0/i; //這是對的
// j=(float)(1/i); //這也是不對的
j=1/(float)(i); //這是對的
sum=sum+j;
}
printf("1+1/2+1/3+......+1/100的值爲:%f\n",sum); //float必須要用%f輸出
return 0;
}
強制類型轉換:
格式:(數據類型)(表達式)
(int)(4.5+2.2)————6
(float)(5)——————5.00000
—————————————————————————————————————————————
—————————————————————————————————————————————
/********************
2011年9月4日21:25:52
目的:浮點數存儲
***********************************/
#include<stdio.h>
int main(void)
{
float i;
float sum = 0;
for(i=1.0;i<=100;i++) //不精確
{
sum=sum+1/i; //不精確
}
printf("sum = %f\n",sum);
return 0;
}
該程序與上程序的區別在於把i定義爲了float數據類型,結果是正確的但是邏輯上存在錯誤
float和double都不能保證可以精確的存儲一個小數。
例如6.234可能在計算機真正存儲的數字是6.23999999
C語言中經常要考的面試題目:
有一個浮點型變量x,如何判斷x的值是否是零????
if(x==0)是 else 不是 //錯誤的
if(|x-0.000001|<0.000001) 是 else不是 //正確的
爲什麼循環中更新的變量不能定義成浮點型?因爲浮點型的非準確存儲