先貼出錯誤算法:
#include<stdio.h> int main() { double a = 3.155; printf("%lf\n", a); a = (int)((a * 100) + 0.5) / 100.0; printf("%lf", a); return 0; }測試 : 據說此方法四舍五入精確到百分位
a = 3.144 >> a == 3.140
a = 3.146 >> a == 3.150
a = 3.145 >> a == 3.140
我去 怎么還帶末尾0? 還有這就是傳說中的五舍六入么? 我懂得少你可別騙我啊!
百度搜索好幾頁 這種結果錯誤算法滿天飛 禁不住想吐槽 能不能敲一敲代碼測試一下啊 各位大神?
編程是看出來的? 編程是練出來的!
讓真理永存吧!
接下來是正確算法
例(精確到百分位即小數點后兩位)
#include<iostream> using namespace std; int main() { float a=3.1465; cout.setf(ios::fixed); cout.precision(2); cout<<a<<endl; return 0; }測試自己去測
總結用法
#include<iostream> //頭文件 主函數中 <pre name="code" class="cpp">cout.setf(ios::fixed); cout.precision(精確到的位數); //0為個位,1位十分位,2位百分位
本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系我们删除。