在 C++ 中把浮点数取整到两位小数
本文将介绍几种在 C++ 中如何将浮点数四舍五入到两位小数的方法。
在 C++ 中使用 printf
函数格式说明符将浮点数四舍五入为 2 个小数
浮点数具有特殊的二进制表示形式,这意味着机器无法精确表示实数。因此,在对浮点数进行运算并对其进行计算时,通常要借助于舍入函数。但是,在这种情况下,我们只需要输出数字的小数部分。
第一种解决方案是利用 printf
函数将格式化的文本输出到 stdout
流。注意,浮点数数字的常规格式说明符-%f
应修改为%.2f
。后一种表示法确保从该数字仅打印 2 个小数,并且同时根据通用数学规则进行舍入。请注意,其他数据类型的格式说明符也可以使用类似的符号。
#include <iostream>
#include <vector>
using std::cout;
using std::endl;
using std::vector;
int main() {
vector<double> floats{-3.512312, -21.1123, -1.99, 0.129, 2.5, 3.111};
for (auto &item : floats) {
printf("%.2f; ", item);
}
return EXIT_SUCCESS;
}
输出:
-3.51; -21.11; -1.99; 0.13; 2.50; 3.11;
在 C++ 中使用 fprintf
函数格式说明符将浮点数舍入到 2 位小数
fprintf
是另一个可以用来做输出格式化的函数,就像 printf
调用一样,此外,它可以写入任何可以作为第一个参数传递的 FILE*
流对象。在下面的示例中,我们演示了打印到 stderr
流,这是 stdout
的无缓冲版本,用于错误报告和日志记录。
#include <iostream>
#include <vector>
using std::cout;
using std::endl;
using std::vector;
int main() {
vector<double> floats{-3.512312, -21.1123, -1.99, 0.129, 2.5, 3.111};
for (auto &item : floats) {
fprintf(stderr, "%.2f; ", item);
}
return EXIT_SUCCESS;
}
输出:
-3.51; -21.11; -1.99; 0.13; 2.50; 3.11;
在 C++ 中使用 std::setprecision
和 std::fixed
将浮点数舍入为 2 个小数
或者,可以将 I/O 机械手库中的 std::setprecision
函数与 std::fixed
一起使用。后者用于修改浮点输入/输出操作的默认格式。如果我们将其与 std::setprecision
一起使用,则结果是实数的固定精度,并且可以通过传递给 std::setprecision
本身的整数参数来指定精度。
#include <iomanip>
#include <iostream>
#include <vector>
using std::cout;
using std::endl;
using std::fixed;
using std::setprecision;
using std::vector;
int main() {
vector<double> floats{-3.512312, -21.1123, -1.99, 0.129, 2.5, 3.111};
for (auto &item : floats) {
cout << setprecision(2) << fixed << item << "; ";
}
return EXIT_SUCCESS;
}
输出:
-3.51; -21.11; -1.99; 0.13; 2.50; 3.11;
相关文章
如何在 C++ 中实现毫秒级的睡眠
发布时间:2024/01/02 浏览次数:124 分类:C++
-
本文介绍了在 C++ 中使用不同方法暂停程序执行,实现睡眠的方法。本文介绍了在 C++ 中睡眠毫秒的方法。使用 std::this_thread::sleep_for 方法在 C++ 中睡眠
如何在 C++ 中将双精度数四舍五入到整数上
发布时间:2024/01/02 浏览次数:88 分类:C++
-
本文演示了如何在 C++ 中把双精度数四舍五入到整数中。本文将为大家讲解几种在 C++ 中如何将双精度数四舍五入为整数的方法。使用 round() 函数将双精度数四舍五入到整数
如何在 C++ 中以毫秒为单位获取时间
发布时间:2024/01/02 浏览次数:60 分类:C++
-
本文介绍了如何在 C++ 中获取以毫秒为单位的时间。本文将介绍多种 C++ 方法,介绍如何以毫秒为单位获取时间。
如何在 C++ 中把 Char 数组转换为 Int
发布时间:2024/01/02 浏览次数:90 分类:C++
-
本文演示了在 C++ 中把 char 数组转换为 int 类型的方法。本文将介绍将 char 数组转换为 int 类型的 C++ 方法。使用 std::strtol 函数将 char 数组转换为 int 类型
如何在 C++ 中将 ASCII 码转换为字符
发布时间:2024/01/02 浏览次数:183 分类:C++
-
本文介绍了在 C++ 中如何将 ASCII 值转换为 char 的方法。本文将演示关于如何在 C++ 中把 ASCII 值转换为字符的多种方法。在 C++ 中使用赋值运算符将 ASCII 值转换为字符
如何在 C++ 中把十进制转换为二进制
发布时间:2024/01/02 浏览次数:71 分类:C++
-
本文介绍如何在 C++ 中把十进制数转换成二进制数。本文将介绍几种在 C++ 中如何将十进制数转换为二进制表示的方法。在 C++ 中使用自定义定义的函数将十进制数转换为二进制数
如何在 C++ 中把枚举型转换为字符串
发布时间:2024/01/02 浏览次数:138 分类:C++
-
本文演示了如何在 C++ 中把枚举转换为字符串。本文将解释几种在 C++ 中把枚举类型转换为 string 变量的方法。使用 const char*数组将枚举类型转换为字符串
在 C++ 创建一个字典
发布时间:2024/01/02 浏览次数:191 分类:C++
-
本文介绍了如何在 C++ 中创建一个字典。使用初始化列表构造函数在 C++ 中创建字典 在 C++ 标准容器库中,有一个名为 std::map 的字典,它实现了具有唯一键的排序键值对。
如何在 C++ 中将文本追加到文件
发布时间:2024/01/02 浏览次数:95 分类:C++
-
本文介绍了如何用 C++ 将文本追加到文件中的方法。使用 std::ofstream 和 open() 方法将文本追加到文件中