迹忆客 专注技术分享

当前位置:主页 > 学无止境 > 编程语言 > C++ >

如何在 C++ 中将双精度数四舍五入到整数上

作者:迹忆客 最近更新:2024/01/02 浏览次数:

本文将为大家讲解几种在 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

转载请发邮件至 1244347461@qq.com 进行申请,经作者同意之后,转载请以链接形式注明出处

本文地址:

相关文章

如何在 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++ 运行命令行

发布时间:2023/09/04 浏览次数:202 分类:C++

本文将简要讨论通过 C++ 程序在命令处理器中运行命令的 system() 方法。C/C++ 提供了一个函数,可以执行此操作,而无需产生另一个可以运行命令行处理器来运行 CMD 命令的进程。

C++ 中的递归 Lambda 函数

发布时间:2023/09/02 浏览次数:203 分类:C++

在本文中,我们将了解 C++ 中可用的递归 lambda。C++ 递归 Lambda 函数 递归是指函数(直接或间接)调用自身的过程,这个过程对应的函数称为递归函数。 递归 lambda 表达式是此过程的结果。

C++状态机的概念

发布时间:2023/09/02 浏览次数:194 分类:C++

本文向我们介绍了 C++ 状态机的概念,说明了如何使用它,并强调了它的优点。C++ 状态机概述 要理解C++中的状态机,我们首先应该了解有限状态机的概念。

C++包含路径的概念

发布时间:2023/09/02 浏览次数:109 分类:C++

包含路径用于告诉编译器在哪里查找头文件。 编译器将在这些路径指定的目录中搜索,直到找到名称匹配的头文件。Visual Studio IDE 中的 C++ 包含路径目录

扫一扫阅读全部技术教程

社交账号
  • https://www.github.com/onmpw
  • qq:1244347461

最新推荐

教程更新

热门标签

扫码一下
查看教程更方便