課程
/后端開發
/C
/C語言入門
為什么把double換成int輸出值就為0.00了呢?
2016-09-24
源自:C語言入門 5-14
正在回答
//我覺得原本是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; }
一條被曬干的咸魚 提問者
??明白了嗎同學,你咋消失了
舉報
C語言入門視頻教程,帶你進入編程世界的必修課-C語言
3 回答為什么把int換為float 答案就輸不出 都是0?
1 回答為什么int不能換double
3 回答為什么不能把double result 改成int result
1 回答為什么把char改成double結果就變了
2 回答為什么double 強制轉換成int 是這樣編寫?
Copyright ? 2025 imooc.com All Rights Reserved | 京ICP備12003892號-11 京公網安備11010802030151號
購課補貼聯系客服咨詢優惠詳情
慕課網APP您的移動學習伙伴
掃描二維碼關注慕課網微信公眾號
2016-09-24
2016-09-24
??明白了嗎同學,你咋消失了