【问题标题】:c++ reversed integer sequence implementationc++反转整数序列实现
【发布时间】:2018-07-18 18:30:13
【问题描述】:
谁知道如何实现 C++ std::make_index_sequence 反向版本。得到 - make_index_sequence_reverse<int, 5> = <4,3,2,1,0>。谢谢!
【问题讨论】:
-
欢迎来到 SO!请查看how to ask questions .- 您可以发布您所做的任何尝试吗?
标签:
c++
templates
c++14
c++17
template-meta-programming
【解决方案1】:
恕我直言,index_sequence_reverse:std::index_sequence 没有理由支持索引序列并且是中性的(甚至没有顺序)。
如果您可以使用std::make_index_sequence,对于makeIndexSequenceReverse,您可以进行如下操作
#include <utility>
#include <type_traits>
template <std::size_t ... Is>
constexpr auto indexSequenceReverse (std::index_sequence<Is...> const &)
-> decltype( std::index_sequence<sizeof...(Is)-1U-Is...>{} );
template <std::size_t N>
using makeIndexSequenceReverse
= decltype(indexSequenceReverse(std::make_index_sequence<N>{}));
int main ()
{
static_assert( std::is_same<std::index_sequence<4U, 3U, 2U, 1U, 0U>,
makeIndexSequenceReverse<5U>>::value, "!" );
}