迹忆客 专注技术分享

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

在 C++ 中定义和使用负无穷大

作者:迹忆客 最近更新:2023/08/19 浏览次数:

本文讨论了在 C++ 中表示负无穷大的问题并列出了一些可能的解决方案。

C++ 使用 IEEE-754 标准来表示浮点数。 浮点数据类型共有三种:float、double 和 long double。

所有这些变量类型都允许存储无法存储在 int 数据类型中的数值。

无穷大在 C++ 中写为 inf,结果是用一个正数值除以一个空值,或者计算出一个大于 64 位可以存储的数值。

无符号或正浮点无穷大值在各种 C++ 库(例如 cmath 和 limit)中定义,但 C++ 中没有负无穷大的标准。

由于 C++ 中没有表示负无穷大的标准方法,因此这里有几种在 C++ 中表示和使用负无穷大的可靠方法。


在 C++ 中使用 numeric_limits::infinity() 的负积

使用 C++ 中的 limits 库。

#include<iostream>
#include<limits>

using namespace std;

int main()
{
    float f = numeric_limits<float>::infinity();

    float negInf= f*-1;

    cout << "The value of f is = " << f << endl;
    cout << "The value of negInf is = " << negInf << endl;
    cout << "The value of f + negInf is = " << f + negInf << endl;

    return 0;
}

在上面的代码片段中,limits 库中的 infinity 方法返回正无穷大的值。

语法如下。

numeric_limits<T>::infinity()

在上面的定义中,尖括号之间的 T 代表模板类,在实际实现中,它被替换为要使用 numeric_limits 方法的数据类型。 在上面的代码片段中,使用了float数据类型,但也可以类似地使用double。

但是,infinity() 方法仅对非整数数据类型有效,因为 int 和 bool 等整数数据类型本质上是有限的。

上述代码的输出如下。

The value of f is = inf
The value of negInf is = -inf
The value of f + negInf is = nan

如上例所示,使用 infinity() 方法,将正无穷大的值赋给 float 类型变量 f。 然后使用一种非常简单直观的方法,即将 f 乘以 -1,并将结果存储在名为 negInf 的变量中,从而将负无穷大的值存储在 negInf 中。

如上面的输出所示,此有效方法将负无穷大值分配给变量。 为了进一步测试这个方法,将f和negInf相加,结果返回nan,它代表Not-a-Number,表示一个无法计算的值。

此结果与无穷大值的 IEEE-754 规则一致,因此计算安全。


使用 cmath 库中的 INFINITY 定义

cmath 库是另一个 C++ 库,具有许多有用的方法和函数来处理常见的数学运算和转换。

该库还包含无穷大值的定义,该定义名为 INFINITY,其使用方式与 numeric_limits<T>::infinity() 大致相同,并且可以直接分配给 float 和 double 数据类型。

使用与上一个示例相同的方法,将无符号或正无穷大的值乘以负值将返回负无穷大值。

#include<iostream>
#include<cmath>

using namespace std;

int main()
{
    long double f = INFINITY;
    long double negInf= f*-1;

    cout << "The value of f is = " << f << endl;
    cout << "The value of negInf is = " << negInf << endl;

    cout << "The value of f + negInf is = " << f + negInf << endl;
    return 0;
}

上述代码的输出如下。

The value of f is = inf
The value of negInf is = -inf
The value of f + negInf is = nan

可以看出,两种方法产生相同的输出,并且都可以安全地用于在 C++ 中实现负无穷大。

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

本文地址:

相关文章

在 C++ 中转换为 SHA256

发布时间:2023/08/19 浏览次数:133 分类:C++

SHA256 转换是一种加密哈希技术,自 90 年代以来一直在使用,但在比特币和区块链出现后获得了重视。它使用一种不可逆的单向哈希技术,这意味着最终答案永远无法逆转回其原始消息,从而使

在 macOS 中编译 C++ 代码

发布时间:2023/08/18 浏览次数:198 分类:C++

本文包含有关 macOS X 的 C++ 编译器的信息。我们将讨论如何使用命令行界面(即终端)使用 g++ 编译器编译和运行代码。

在 Dev C++ 中编译并运行 C++ 11 代码

发布时间:2023/08/18 浏览次数:79 分类:C++

本文是关于使用 Dev C++ 编译 C++ 11 代码。C++ 11 版本 C++ 11是继C++ 3之后的C++新版本,经国际标准组织(ISO)批准于2011年8月12日发布。

C++ 中的清除字符串流

发布时间:2023/08/18 浏览次数:119 分类:C++

本文将介绍在 C++ 中清除或清空字符串流的不同方法。在C++中使用str("")和clear()方法清除字符串流 要清除或清空字符串流,我们可以使用 str("") 和 clear() 方法,但我们必须同时使用这两种方法

在 C++ 中获取文件的 MD5 哈希值

发布时间:2023/08/18 浏览次数:62 分类:C++

MD5 是一种密码协议,以前用于加密,但现在通常用于身份验证。 它基于哈希函数中的哈希过程,针对某些纯文本生成加密的哈希值。什么是哈希函数 在探索 MD5(消息摘要算法)之前,了解哈

将 C# 代码转换为 C++

发布时间:2023/08/18 浏览次数:183 分类:C++

本指南将讨论如何将 C# 代码转换为 C++。将整个语言转换为另一种语言被认为几乎是不可能的。 在这种情况下,C# 到 C++ 代码适用于 Unix,但 .NET Framework 无法从 Unix 上的 C++ 获得。

在 C++ 中使用 extern C

发布时间:2023/08/18 浏览次数:140 分类:C++

本文讨论 C++ 中的名称重整,这是理解 C++ 中 extern "C" 影响的先决条件。 此外,它还介绍了 C++ 编程中的 extern“C”。C++ 中 extern "C" 的使用 我们使用extern关键字来定义全局变量,也称为外部变量

C++中的串口连接

发布时间:2023/08/18 浏览次数:151 分类:C++

本文介绍了使用 Windows API 打开、读取、写入和管理串行端口连接的基础知识。本文的主要目的是让您基本了解编程中的串行通信如何工作,并让您朝着正确的方向开始。

扫一扫阅读全部技术教程

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

最新推荐

教程更新

热门标签

扫码一下
查看教程更方便