C语言温度转换窗体,C语言1_1:温度转换
上機1_1:溫度轉換
int main()
{
int f;
float c;
scanf(
"%d", &f );
//c =
5/9*(f-32);
c =
5.0/9*(f-32);
printf(
"%.2f\n", c );
return 0;
}
現象:c = 5.0/9*(f-32)正確,輸入93,輸出33.98;
c =
5/9*(f-32)錯誤,輸入93,輸出0.00;
c語言的類型轉換:
語句和表達式通常應該是只使用一種類型的變量和常量,但如果你使用了混合類型,C則會用一個規則集合來自動完成類型的轉換。這可能很方便,但也可能很危險,尤其在你無意地混合使用了不同類型的情況下。
隱式類型轉換規則:
C語言自動轉換不同類型的行為稱之為隱式類型轉換
,轉換的基本原則是:低精度類型向高精度類型轉換,具體是:
int -> unsigned int -> long -> unsigned long
-> long long -> unsigned long long -> float -> double -> long
double
注意,上面的順序并不一定適用于你的機器,比如當int和long具有相同字長時,unsigned int的精度就會比long的精度高(事實上大多數針對32機的編譯器都是如此)。另外需要注意的一點是并沒有將char和short型寫入上式,原因是他們可以被提升到int也可能被提升到unsigned int。
提升數據的精度通常是一個平滑無損害的過程,但是降低數據的精度可能導致真正的問題。原因很簡單:一個較低精度的類型可能不夠大,不能存放一個具有更高精度的完整的數據。一個1字節的char變量可以存放整數101但不能存放整數12345。當把浮點類型數據轉換為整數類型時,他們被趨零截尾或舍入。
強制類型轉換:
通常我們應該避免自動類型轉換,當我們需要手動指定一個準確的數據類型時,我們可以用強制類型轉換機制來達到我們的目的,使用方法很簡單,在需要強制轉換類型的變量或常量前面加上(type),例如(double)i;即把變量i強制轉換成double型。
在c = 5/9*(f-32)中,右邊是int,結果為0,左邊是float,發生隱式類型轉換,c為0.00;
在c = 5.0/9*(f-32)中,(f-32)的為int,結果為61,5.0/9發生隱式類型轉換,轉換為float,結果為9分之5,相乘為float,結果為33.98
因此,題中語句有兩種寫法:
c = 5.0/9*(f-32); --------------------發生隱式類型轉換
c = (float)5/9*(f-32);--------------強制類型轉換
int main()
{
int f;
int c1,c2;
float c;
scanf( "%d", &f );
//c = 5/9*(f-32);
c1 = 5/9*(f-32);
c2 = (float)5/9*(f-32);
c =
5.0/9*(f-32);
printf(
"%d\n", c1 );-----------輸出0
printf(
"%d\n", c2 );-----------輸出33
printf(
"%.2f\n", c );----------輸出33.98
return 0;
}
總結
以上是生活随笔為你收集整理的C语言温度转换窗体,C语言1_1:温度转换的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 一阶LC谐振电路
- 下一篇: 关于教师节想到的礼物