问题
Who knows how to implement C++ std::make_index_sequence
reverse version. To get - make_index_sequence_reverse<int, 5> = <4,3,2,1,0>
. Thank you!
回答1:
IMHO, there is no reason for a index_sequence_reverse
: std::index_sequence
support sequences of indexes and are order neutral (or even without order).
If you can use std::make_index_sequence
, for a makeIndexSequenceReverse
you can make something as follows
#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, "!" );
}
来源:https://stackoverflow.com/questions/51408771/c-reversed-integer-sequence-implementation