從“求1+1/2+1/3+......+1/100”中觀察類型轉換和浮點型的數據存儲

 

/*********************
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不是   //正確的

爲什麼循環中更新的變量不能定義成浮點型?因爲浮點型的非準確存儲

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章