如何在 C++ 中将双精度数四舍五入到整数上
本文将为大家讲解几种在 C++ 中如何将双精度数四舍五入为整数的方法。
使用 round()
函数将双精度数四舍五入到整数
round()
函数在 <cmath>
头中定义。它可以计算用户传递的参数的最接近的整数值。半数情况下会从零开始四舍五入,并且返回的值与参数的类型相同。在下面的例子中,我们初始化一个任意的双精度数向量,并为每个元素输出 round()
函数。
#include <cmath>
#include <iostream>
#include <vector>
using std::cout;
using std::endl;
using std::vector;
int main() {
vector<double> dfloats{-3.5, -21.1, -1.99, 0.129, 2.5, 3.111};
for (auto &item : dfloats) {
cout << "round(" << item << ") = " << round(item) << endl;
}
return EXIT_SUCCESS;
}
输出:
round(-3.5) = -4
round(-21.1) = -21
round(-1.99) = -2
round(0.129) = 0
round(2.5) = 3
round(3.111) = 3
使用 lround()
函数将双精度数转换为最接近的整数
或者,我们可以使用 lround()
函数,它的行为与 round()
几乎相同,但有一点不同:它以 long
整数格式返回值。需要注意的是,对于这两个函数来说,返回值可能会出乎意料,这是由普遍存在的不同舍入误差引起的。应按照文档中的规定进行处理。
#include <cmath>
#include <iostream>
#include <vector>
using std::cout;
using std::endl;
using std::vector;
int main() {
vector<double> dfloats{-3.5, -21.1, -1.99, 0.129, 2.5, 3.111};
for (auto &item : dfloats) {
cout << "round(" << item << ") = " << lround(item) << endl;
}
return EXIT_SUCCESS;
}
使用 trunc()
函数双精度数四舍五入到整数
trunc()
是 <cmath>
头文件中的另一个有用的函数,它计算不大于作为参数传递的数字的最近的整数。trunc()
和 round()
一样,以浮点格式计算返回值。注意,这两个函数不会对当前的四舍五入模式产生任何影响。错误处理情况在手册页中描述。
#include <cmath>
#include <iostream>
#include <vector>
using std::cout;
using std::endl;
using std::vector;
int main() {
vector<double> dfloats{-3.5, -21.1, -1.99, 0.129, 2.5, 3.111};
for (auto &item : dfloats) {
cout << "round(" << item << ") = " << trunc(item) << endl;
}
return EXIT_SUCCESS;
}
round(-3.5) = -3
round(-21.1) = -21
round(-1.99) = -1
round(0.129) = 0
round(2.5) = 2
round(3.111) = 3
相关文章
如何在 C++ 中实现毫秒级的睡眠
发布时间:2024/01/02 浏览次数:124 分类:C++
-
本文介绍了在 C++ 中使用不同方法暂停程序执行,实现睡眠的方法。本文介绍了在 C++ 中睡眠毫秒的方法。使用 std::this_thread::sleep_for 方法在 C++ 中睡眠
在 C++ 中以右对齐输出
发布时间:2024/01/02 浏览次数:148 分类:C++
-
本文介绍了如何在 C++ 中对输出进行右对齐的方法。本文将演示关于如何在 C++ 中对输出流进行右对齐的多种方法。使用 std::right 和 std::setw 在 C++ 中对输出进行右对齐
在 C++ 中查找字符串中的第一个重复字符
发布时间:2023/09/04 浏览次数:234 分类:C++
-
在本文中,您将学习如何在 C++ 中查找字符串中的第一个重复字符。 您将学习实现此目的的三种方法:散列技术、暴力方法和算法的编写。在 C++ 中查找字符串中的第一个重复字符
求 C++ 中的最长公共子串
发布时间:2023/09/04 浏览次数:163 分类:C++
-
在本文中,我们将讨论最长公共子串问题及其在 C++ 中使用动态规划的解决方案。最长公共子串 最长公共子串(LCS)是计算机科学中的一个众所周知的问题。
C++ 中字符串的第一个字母大写
发布时间:2023/09/04 浏览次数:125 分类:C++
-
本文将介绍将字符串的第一个字母转换为大写的各种方法。C++ 中字符串的第一个字母大写 我们将分三种不同的情况来处理这个问题:
C++ 中的递归 Lambda 函数
发布时间:2023/09/02 浏览次数:203 分类:C++
-
在本文中,我们将了解 C++ 中可用的递归 lambda。C++ 递归 Lambda 函数 递归是指函数(直接或间接)调用自身的过程,这个过程对应的函数称为递归函数。 递归 lambda 表达式是此过程的结果。
C++包含路径的概念
发布时间:2023/09/02 浏览次数:109 分类:C++
-
包含路径用于告诉编译器在哪里查找头文件。 编译器将在这些路径指定的目录中搜索,直到找到名称匹配的头文件。Visual Studio IDE 中的 C++ 包含路径目录