C++保留小數位數問題
首先
介紹主角:
setprecision() 和 setiosflags()
這兩個函式是標頭檔案#include<iomanip>裡的函式,記得加標頭檔案#include<iomanip>
setprecision()
顧名思義:就是設定精度。用來控制輸出的數的位數(從左到右的),自動四捨五入。且不保留小數後的0。比如:
int pi = 3.1415926000;
cout<<setprecision(1)<<pi<<endl;
>>> 3
cout<<setprecision(2)<<pi<<endl;
>>> 3.1
cout<<setprecision(5)<<pi<<endl;
>>> 3.1416
(四捨五入)
cout<<setprecision(10)<<pi<<endl;
>>> 3.1415926
(末尾不保留0)
我們可以使用這個函式初步控制小數位數。但是呢
如果整數部分不確定,或者要求末尾保留0的時候,那我們就無法準確保留適當的小數位數,因此我們需要另一個函式:
setiosflags():
我們在這裡主要用到其中兩個:fixed 和 showpoint。
首先說fixed,以定點方式顯示實數,即顯示整數部分。舉個栗子:
int pi = 3.1415926000;
cout<<setiosflags(ios::fixed)<<setprecision(2)<<pi<<endl;
>>> 3.14
cout<<setiosflags(ios::fixed)<<setprecision(4)<<pi<<endl;
>>> 3.1416
可見此時setprecision()已經是隻控制小數位數了,但是:
cout<<setiosflags(ios::fixed)<<setprecision(10)<<pi<<endl;
>>> 3.1415926
它仍然不能保留0。這時就有了showpoint。
還是那個例子:
cout<<setiosflags(ios::fixed|ios::showpoint)<<setprecision(10)<<pi<<endl;
>>> 3.1415926000
這樣我們就能完全控制小數位數的輸出了。