借助相同的std::find_if,我们可以实现这一目标。
以下是一个模板函数,它采用迭代器(就像在大多数标准算法函数中一样)
二维数组(std::vector<std::vector<Type>>,或
std::array<std::array<Type, RowSize>, ColSize>) 并返回指向内部数组(元素存在的地方)的迭代器,否则
二维数组的结束迭代器。
(See Live Online)
#include <type_traits> // std::remove_reference_t, std::remove_const_t, std::conditional_t, std::is_fundamental_v
#include <iterator> // std::cbegin(), std::cend()
#include <algorithm> // std::find_if
#include <utility> // std::declval
// traits for finding the inner element type of 2D array(of std::vector or std::array)
template<typename Iterator>
using ContainerType = std::remove_const_t<std::remove_reference_t<decltype(*std::declval<Iterator>())>>;
template<typename Iterator>
using ElementType = std::remove_const_t<std::remove_reference_t<typename ContainerType<Iterator>::value_type>>;
template<typename Iterator> // optional: ElementType<Iterator> should also be enough!
using ElementArgumentType = std::conditional_t<std::is_fundamental_v<ElementType<Iterator>>
, ElementType<Iterator>, ElementType<Iterator> const&>;
template<typename Iterator>
auto isIn2DArray(
Iterator begin, const Iterator end, ElementArgumentType<Iterator> val) noexcept
{
// used the standard algorithm std::find_if here!
return std::find_if(begin, end, [val](const auto& row) noexcept {
return std::find_if(std::cbegin(row), std::cend(row), [val](const auto& element) noexcept {
return element == val;
}
) != std::cend(row);
}
);
}
或者将一元谓词传递给函数,该函数将用于在数组数组中查找适当的数组。这样噪音会小一点!
(See Live Online)
#include <iterator> // std::cbegin(), std::cend()
#include <algorithm> // std::find_if
template<typename Iterator, typename UnaryPredicate>
auto find_if_in_2DArray(
Iterator begin, const Iterator end, UnaryPredicate unarayPred) noexcept
{
// used the standard algorithm std::find_if here!
return std::find_if(begin, end, [unarayPred](const auto& row) noexcept {
return std::find_if(std::cbegin(row), std::cend(row), unarayPred) != std::cend(row);
}
);
}