【问题标题】: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, "!" );
 }

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2012-04-14
    • 2020-02-14
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多