日本免费高清视频-国产福利视频导航-黄色在线播放国产-天天操天天操天天操天天操|www.shdianci.com

學無先后,達者為師

網站首頁 編程語言 正文

c++只保留float型的小數點后兩位問題_C 語言

作者:爬行的菜鳥 ? 更新時間: 2022-12-08 編程語言

c++ 只保留float型的小數點后兩位

float spd = 22.518744;
char buf[10];
sprintf(buf, "%.2f", spd);
sscanf(buf, "%f", &spd);

記錄一下,有時候我們需要float類型只保留兩個有效小數,但是在實際應用中會發現一些現象

如:1.5 在實際中為1.49999998 等等

還有一個常用的方法同時進行四舍五入:

float ff = 36.51647;
ff = ( (float)( (int)( (ff + 0.005) * 100 ) ) ) / 100;

但是有時候效果也不理想

C++ cout輸出小數點后指定位數

在C++的編程中,總會遇到浮點數的處理,有的時候,我們只需要保留2位小數作為輸出的結果,這時候,問題來了,怎樣才能讓cout輸出指定的小數點后保留位數呢?

在C語言的編程中,我們可以這樣實現它:

printf("%.2f", sample);

在C++中,是沒有格式符的,我們可以通過使用setprecision()函數來實現這個需求。

想要使用setprecision()函數,必須包含頭文件#include 。

使用方式如下:

cout << "a=" << setprecision(2) << a <<endl;

這時候,我們會發現,如果a的值為0.20001,輸出的結果為a=0.2,后面第二位的0被省略了。

如果我們想要讓它自動補0,需要在cout之前進行補0的定義。

代碼如下:

cout.setf(ios::fixed);
cout << "a=" <<fixed<< setprecision(2) << a <<endl; //輸出a=0.20

這樣,我們就可以得到0.20了。當然,如果想要關閉掉補0,只需要對fixed進行取消設置操作。

cout.unsetf(ios::fixed);
cout << "a=" << setprecision(2) << a <<endl; //輸出a=0.2

我們的輸出結果就又變回a=0.2了。

參考代碼

#include <iostream>
#include <iomanip>
?
using namespace std;
?
int main()
{
? ? float a = 0.20001;
? ? cout.setf(ios::fixed);
? ? cout << "a=" <<fixed<< setprecision(2) << a <<endl; //輸出結果為a=0.20
? ? cout.unsetf(ios::fixed);
? ? cout << "a=" << setprecision(2) << a <<endl; //輸出結果為a=0.2
? ? return 0;
}

原文鏈接:https://blog.csdn.net/zb774095236/article/details/89493283

欄目分類
最近更新