计算成对数组中成对元素的差异编译时间
Compute differences of pair elements in array of pairs compile time
在下面的代码中,我的目标是构造一个 N
元素数组,其中包含两个 std::pair
元素编译时的差异。有没有办法使用模板来实现这一点,因为它必须适用于任意大小 N
?
#include <array>
#include <utility>
template<int N>
std::array<int, N> make_array(
const std::array<std::pair<int, int>, N>& ranges)
{
// Need to construct array compile time with difference between pair elements.
}
int main()
{
std::array<int, 2> a = make_array<2>({{ {1,3}, {2,9} }}); // a = {2, 7}
std::array<int, 1> b = make_array<1>({{ {5,6} }}); // b = {1}
return 0;
}
如果你能使用 C++14(所以 std::make_index_sequence
/std::index_sequence
)就很容易了
#include <array>
#include <utility>
template <std::size_t N, std::size_t ... Is>
constexpr std::array<int, N> makeArrayHelper
(std::array<std::pair<int, int>, N> const & r,
std::index_sequence<Is...> const)
{ return {{ r[Is].second - r[Is].first ... }}; }
template <std::size_t N>
constexpr auto makeArray (std::array<std::pair<int, int>, N> const & r)
{ return makeArrayHelper(r, std::make_index_sequence<N>{}); }
int main ()
{
constexpr std::array<int, 2> a
= makeArray<2>({{ {1,3}, {2,9} }}); // a = {2, 7}
constexpr std::array<int, 1> b
= makeArray<1>({{ {5,6} }}); // b = {1}
static_assert( a[0] == 2, "!" );
static_assert( a[1] == 7, "!" );
static_assert( b[0] == 1, "!" );
}
P.s.: 我重命名了 makeArray()
函数以减少与 std::experimental
中的 make_array()
名称冲突的风险
您可以简单地执行循环:
template <std::size_t N>
constexpr std::array<int, N> make_array(
const std::array<std::pair<int, int>, N>& ranges)
{
std::array<int, N> res{};
for (std::size_t i = 0; i != N; ++i) {
res[i] = ranges[i].second - ranges[i].first;
}
return res;
}
从 C++17 开始可能是 constexpr
。
在下面的代码中,我的目标是构造一个 N
元素数组,其中包含两个 std::pair
元素编译时的差异。有没有办法使用模板来实现这一点,因为它必须适用于任意大小 N
?
#include <array>
#include <utility>
template<int N>
std::array<int, N> make_array(
const std::array<std::pair<int, int>, N>& ranges)
{
// Need to construct array compile time with difference between pair elements.
}
int main()
{
std::array<int, 2> a = make_array<2>({{ {1,3}, {2,9} }}); // a = {2, 7}
std::array<int, 1> b = make_array<1>({{ {5,6} }}); // b = {1}
return 0;
}
如果你能使用 C++14(所以 std::make_index_sequence
/std::index_sequence
)就很容易了
#include <array>
#include <utility>
template <std::size_t N, std::size_t ... Is>
constexpr std::array<int, N> makeArrayHelper
(std::array<std::pair<int, int>, N> const & r,
std::index_sequence<Is...> const)
{ return {{ r[Is].second - r[Is].first ... }}; }
template <std::size_t N>
constexpr auto makeArray (std::array<std::pair<int, int>, N> const & r)
{ return makeArrayHelper(r, std::make_index_sequence<N>{}); }
int main ()
{
constexpr std::array<int, 2> a
= makeArray<2>({{ {1,3}, {2,9} }}); // a = {2, 7}
constexpr std::array<int, 1> b
= makeArray<1>({{ {5,6} }}); // b = {1}
static_assert( a[0] == 2, "!" );
static_assert( a[1] == 7, "!" );
static_assert( b[0] == 1, "!" );
}
P.s.: 我重命名了 makeArray()
函数以减少与 std::experimental
make_array()
名称冲突的风险
您可以简单地执行循环:
template <std::size_t N>
constexpr std::array<int, N> make_array(
const std::array<std::pair<int, int>, N>& ranges)
{
std::array<int, N> res{};
for (std::size_t i = 0; i != N; ++i) {
res[i] = ranges[i].second - ranges[i].first;
}
return res;
}
从 C++17 开始可能是 constexpr
。