当前位置:主页 > c/c++教程 > c++保留float型小数点后两位

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

发布:2023-03-12 09:00:01 59


给寻找编程代码教程的朋友们精选了相关的编程文章,网友戌雅逸根据主题投稿了本篇教程内容,涉及到c++保留小数点后两位、float型小数点后两位、保留float小数点后两位、c++保留float型小数点后两位相关内容,已被678网友关注,相关难点技巧可以阅读下方的电子资料。

c++保留float型小数点后两位

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 <

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

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

代码如下:

cout.setf(ios::fixed);
cout << "a=" <

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

cout.unsetf(ios::fixed);
cout << "a=" << setprecision(2) << a <

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

参考代码

#include 
#include 
 
using namespace std;
 
int main()
{
    float a = 0.20001;
    cout.setf(ios::fixed);
    cout << "a=" <

参考资料

相关文章

网友讨论