C++中格式化浮点数常用iostream和iomanip,通过setprecision控制有效位或小数位,fixed固定小数格式,setw与setfill补零,scientific启用科学计数法。

在C++中格式化输出浮点数,常用的方法是通过iostream和iomanip头文件中的工具来控制精度、小数位数、补零、科学计数法等。下面介绍几种常用的格式化方式。
使用std::setprecision可以设置浮点数输出的有效数字或小数位数,具体行为取决于是否启用了fixed。
默认情况下,setprecision(n)表示总共显示n个有效数字。
示例:
立即学习“C++免费学习笔记(深入)”;
#include <iostream>
#include <iomanip>
int main() {
double num = 3.1415926;
std::cout << std::setprecision(5) << num << std::endl;
// 输出:3.1416(共5位有效数字)
std::cout << std::fixed << std::setprecision(2) << num << std::endl;
// 输出:3.14(保留2位小数)
return 0;
}
使用std::fixed可以让浮点数以固定小数位格式输出,而不是自动切换为科学计数法。
示例:
立即学习“C++免费学习笔记(深入)”;
std::cout << std::fixed << std::setprecision(3); std::cout << 12.1 << std::endl; // 输出:12.100 std::cout << 0.00123 << std::endl; // 输出:0.001
如果希望在输出时补前导零(如时间、编号),可结合std::setw和std::setfill。
注意:setw只对下一次输出有效。
示例:
立即学习“C++免费学习笔记(深入)”;
#include <iomanip>
double value = 3.14;
std::cout << std::setfill('0') << std::setw(8) << std::fixed << std::setprecision(2) << value << std::endl;
// 输出:00003.14(总宽8位,前面补0)
使用std::scientific强制以科学计数法输出浮点数。
示例:
立即学习“C++免费学习笔记(深入)”;
std::cout << std::scientific << std::setprecision(3); std::cout << 1234.567 << std::endl; // 输出:1.235e+03
基本上就这些常用方法。结合fixed、setprecision、setw等,可以灵活控制浮点数的显示格式,满足不同场景需求。不复杂但容易忽略细节,比如fixed的影响范围或setw的单次有效性。
c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号