1. 程式人生 > >C++保留小數位數問題

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

這樣我們就能完全控制小數位數的輸出了。