如何检查数组索引是否存在

How to check if array index exists

本文关键字:数组 索引 是否 存在 检查 何检查      更新时间:2023-10-16

我有一个指针* double数组,基本上,它们以任何顺序进行索引。

例如

double[0][0] = 80.0
double[3][0] = 56.8
double[4][0] = 56.7

例如,我如何检查double[1][2]是否存在,如果不存在,则创建一个。

我不打算使用vectors或任何'fancy',只是普通数组。

嗯。好吧,如果你真的想用普通数组来做(为什么?(,除了依靠魔术值之外,你无能为力。我建议std::numeric_limits<double>::quiet_NaN()(NaN = 不是一个数字(。也就是说:

#include <algorithm>
#include <limits>
double data[10][20]; // maximum dimensions mandatory with arrays. There's
                     // no way around that, and you can't grow it later.
std::fill(data[0], data[0] + 10 * 20, std::numeric_limits<double>::quiet_NaN());

然后你可以稍后检查数组中是否有真正的值,如下所示:

if(!std::isnan(data[1][2])) {          // #include <cmath> for std::isnan
  // oh, look, there's a value here!
} else {
  // Nothing here yet. Better fill it
  data[1][2] = 123.0;
}

警告:如果你的计算本身可能产生 NaN 值,你就这样搞砸了。例如,如果您尝试计算0.0 / 0.0std::sqrt(-1)std::log(-1)或其他在实数中没有定义值的东西,就会发生这种情况。如果您的计算产生 NaN 并将其写入数组,则此方法将充当值从未写入该值的情况。