在 C++ 中定义和使用负无穷大
本文讨论了在 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++ 中实现负无穷大。
相关文章
C++ 中的异常 Warning: Cast From Pointer to Integer of Different Size
发布时间:2023/08/19 浏览次数:106 分类:C++
-
这篇快速文章是关于 C++ 中 cast from pointer to integer of different size 警告的解决方案。 该警告通常在不同的编译器上显示为错误。C++ 中 Warning: Cast From Pointer to Integer of Different Size
在 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关键字来定义全局变量,也称为外部变量