纯C++设置浮点数精度

用纯C++语法输出固定位数小数的方法简直不要太麻烦。

首先需要用到一个专用头文件<iomanip>,还需要用到一个流操作符setprecision,用于设置输出流中浮点数的精度。

比如设置π的精度。

cpp 复制代码
#include <iostream>
#include <iomanip> // 包含 setprecision 的头文件
int main() {
    double pi = 3.14159265358979323846;
    // 设置精度为 2,并输出3.1
    std::cout << std::setprecision(2) << pi << std::endl;
    // 设置精度为 5,并输出3.1416
    std::cout << std::setprecision(5) << pi << std::endl;
    // 设置精度为 10,并输出3.141592654
    std::cout << std::setprecision(10) << pi << std::endl;
    return 0;
}

可见,用setprecision设置精度是包括整数部分的,即它指的是总的有效数字位数。

如果你想要保留到小数点后几位,还需要引入另一个小伙伴:fixed

cpp 复制代码
#include <iostream>
#include <iomanip> // 包含 setprecision 的头文件
int main() {
    double pi = 3.14159265358979323846;
    // 设置精度为 2,并输出3.14
    std::cout << std::fixed <<  std::setprecision(2) << pi << std::endl;
    // 设置精度为 5,并输出3.14159
    std::cout << std::fixed << std::setprecision(5) << pi << std::endl;
    // 设置精度为 10,并输出3.1415926536
    std::cout << std::fixed << std::setprecision(10) << pi << std::endl;
    return 0;
}

当然了,如果在main函数前用了using namespace std;的话,代码中的std::就可以省去了,不过即便是这样,这种语法明显也比C语言麻烦的多。

相关推荐
chase_my_dream几秒前
A-LOAM中scanRegistration.cpp详细讲解
c++·人工智能·自动驾驶
肖爱Kun17 分钟前
STL标准模块库操作
开发语言·音视频
Song_da_da_20 分钟前
C# 接口(Interface)深度解析:规范、解耦与灵活扩展
开发语言·c#
政沅同学32 分钟前
基于 C# WPF + HALCON 的工业视觉算法工具框架(开源)
开发语言·c#·wpf
王老师青少年编程32 分钟前
2022年CSP-X复赛真题及题解(T1:独木桥)
c++·真题·csp·信奥赛·复赛·独木桥·csp-x
影寂ldy35 分钟前
C#WinForm 窗体基础(入口、部分类、属性、生命周期事件)
开发语言·c#
2301_7818335236 分钟前
Python 正则表达式入门教程
开发语言·python·正则表达式
gihigo199837 分钟前
基于蒙特卡洛的异常值剔除(RANSAC + MC置信区间)—MATLAB实现
开发语言·算法·matlab
Ting.~1 小时前
在java中接入百度地图
java·开发语言·dubbo
小短腿的代码世界1 小时前
Qt对象树析构链与智能指针协同:零泄漏内存管理架构
开发语言·qt·架构