开发者

c++只保留float型的小数点后两位问题

开发者 https://www.devze.com 2022-12-02 13:24 出处:网络 作者: 爬行的菜鸟
目录c++ 只保留float型的小数点后两位C++ cout输出小数点后指定位数参考代码c++ 只保留float型的小数点后两位
目录
  • c++ 只保留float型的小数点后两位
  • C++ cout输出小数点后指定位数
    • 参考代码

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)开发者_JAVA << a <<endl;

这时候,我们会发现,如果a的值为0.20001,输出的结果为a=0.2,后面第二位的0zxpovx被省略了。

如果我们想要让它自动补0,需要在cout之前进行补0的定义。

代码如下:

cout.setf(IOS::fixed);
cout << "a=" <<fixed<<js; setprecision(2) << a <<endl; //输出a=0.20

这样,我们就可以得到0.20了。当然,如果想要关闭掉补0,只需要对fixed进行取消设置操作。

cout.unsetf(ios::fixed);
cout << "a=" << setprecision(2) << a <<http://www.devze.comendl; //输出a=0.2

我们的输出结果就又变回a=0.2了。

参考代码

#include <iostream>
#include <iomanip>

using namespace std;

int main()
{
  float a = 0.20001;
  cout.setf(ios::fixed);
  cout <&jslt; "a=" <<fixed<< setprecision(2) << a <<endl; //输出结果为a=0.20
  cout.unsetf(ios::fixed);
  cout << "a=" << setprecision(2) << a <<endl; //输出结果为a=0.2
  return 0;
}

以上为个人经验,希望能给大家一个参考,也希望大家多多支持我们。

0

精彩评论

暂无评论...
验证码 换一张
取 消

关注公众号