c++中nan,inf详解

nan: not a number 非数字

注意事项:对负数开方sqrt(-1.0)、对负数求对数(log(-1.0))、0.0/0.0、0.0*inf、inf/inf、inf-inf这些操作都会得到nan。(0/0会产生操作异常;0.0/0.0不会产生操作异常,而是会得到nan)

辨别方法:isnan() : ture is a nan, false otherwise

 
isnan(NaN) = true
isnan(Inf) = false
isnan(0.0) = false
isnan(DBL_MIN/2.0) = false
isnan(0.0 / 0.0)   = true
isnan(Inf - Inf)   = true

inf :  infinity 无穷大的数,一般是超过浮点数的表示范围。

注意事项:

1. 1.0/0.0等于inf,-1.0/0.0等于-inf,0.0+inf=inf;

2. 1.0/inf等于0.0

3. inf是可以与其他浮点数进行比较的,即可以参与<=、>+、==、!=等运算。

辨别方法:isinf(): ture is a nan, false otherwise

isinf(NaN) = false
isinf(Inf) = true
isinf(0.0) = false
isinf(exp(800)) = true
isinf(DBL_MIN/2.0) = false

另一个辨别方法:isfinite():ture is a finite value, false otherwise。可用来一起判断inf和nan。

isfinite(NaN) = false
isfinite(Inf) = false
isfinite(0.0) = true
isfinite(exp(800)) = false
isfinite(DBL_MIN/2.0) = true



  • 25
    点赞
  • 83
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
C++的vector是一个动态数组,具有可变大小,可以在运行时向其添加或删除元素。以下是vector的用法详解: 1. 头文件 使用vector需要包含头文件vector。 ```c++ #include <vector> ``` 2. 创建vector 可以使用以下方式创建vector: ```c++ // 创建一个空的vector std::vector<int> vec1; // 创建一个有5个元素的vector,每个元素都是0 std::vector<int> vec2(5); // 创建一个有3个元素的vector,每个元素的初始值是1 std::vector<int> vec3(3, 1); // 创建一个vector,初始化为另一个vector std::vector<int> vec4(vec3); ``` 3. 访问vector元素 可以使用以下方式访问vector的元素: ```c++ std::vector<int> vec{1, 2, 3, 4, 5}; // 使用下标访问元素 int a = vec[0]; // 使用at函数访问元素 int b = vec.at(1); // 使用front函数访问第一个元素 int c = vec.front(); // 使用back函数访问最后一个元素 int d = vec.back(); ``` 4. 添加元素 可以使用以下方式向vector添加元素: ```c++ std::vector<int> vec{1, 2, 3}; // 在尾部添加一个元素 vec.push_back(4); // 在指定位置插入一个元素 vec.insert(vec.begin() + 2, 5); // 在尾部添加另一个vector的所有元素 std::vector<int> vec2{6, 7, 8}; vec.insert(vec.end(), vec2.begin(), vec2.end()); ``` 5. 删除元素 可以使用以下方式删除vector的元素: ```c++ std::vector<int> vec{1, 2, 3, 4, 5}; // 删除尾部元素 vec.pop_back(); // 删除指定位置的元素 vec.erase(vec.begin() + 2); // 删除指定范围的元素 vec.erase(vec.begin() + 1, vec.begin() + 3); // 删除所有元素 vec.clear(); ``` 6. 获取vector信息 可以使用以下方式获取vector的信息: ```c++ std::vector<int> vec{1, 2, 3, 4, 5}; // 获取元素个数 int size = vec.size(); // 获取容量 int capacity = vec.capacity(); // 判断vector是否为空 bool empty = vec.empty(); ``` 以上是vector的基本用法,可以根据实际需要对其进行扩展。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值