虽然这是可以做到的(实例),但你不应该这样做。这将会花费太多的编译时间。
编译器并没有被设计用于快速、高效的数值大规模处理。现在,限制你的编译时工作只做相对简单的事情,而不是对1000万个元素进行排序。
即使你写了"合规"代码,今天大多数的编译器也会崩溃。我写的代码很早以前就出问题了,尽管我试图小心地控制递归深度限制。
无论如何,为了后代:
template<class T>struct tag;
template<class Tag>using type_t=typename Tag::type;
template<int...Xs> struct values ; };
template<int...Xs> constexpr values<Xs...> values_v = ;
template<class...Vs> struct append;
template<class...Vs> using append_t=type_t<append<Vs...>>;
template<class...Vs> constexpr append_t<Vs...> append_v = ;
template<> struct append<>:tag<values<>>;
template<int...Xs>struct append<values<Xs...>>:tag<values<Xs...>>;
template<int...Lhs, int...Rhs, class...Vs>
struct append<values<Lhs...>,values<Rhs...>,Vs...>:
tag<append_t<values<Lhs...,Rhs...>,Vs...>>
;
template<int...Lhs>
constexpr values<Lhs...> simple_merge( values<Lhs...>, values<> ) ; }
template<int...Rhs>
constexpr values<Rhs...> simple_merge( values<>, values<Rhs...> ) ; }
constexpr values<> simple_merge( values<>, values<> ) ; }
template<int L0, int...Lhs, int R0, int...Rhs>
constexpr auto simple_merge( values<L0, Lhs...>, values<R0, Rhs...> )
-> std::conditional_t<
(R0 < L0),
append_t< values<R0>, decltype( simple_merge( values<L0,Lhs...>, values<Rhs...> ) ) >,
append_t< values<L0>, decltype( simple_merge( values<Lhs...>, values<R0, Rhs...> ) ) >
> ;
}
template<class Lhs, class Rhs>
using simple_merge_t = decltype( simple_merge( Lhs, Rhs ) );
template<class Lhs, class Rhs>
constexpr simple_merge_t<Lhs, Rhs> simple_merge_v = ;
template<class Values, size_t I> struct split
;
template<class Values, size_t I> using split_t=type_t<split<Values, I>>;
template<class Values> struct split<Values, 0>;
template<int X0, int...Xs> struct split<values<X0, Xs...>, 1> ;
template<class Values, size_t I> using before_t = typename split<Values, I>::lhs;
template<class Values, size_t I> using after_t = typename split<Values, I>::rhs;
template<size_t I>using index_t=std::integral_constant<size_t, I>;
template<int I>using int_t=std::integral_constant<int, I>;
template<int I>constexpr int_t<I> int_v=;
template<class Values> struct front;
template<int X0, int...Xs> struct front<values<X0, Xs...>>:tag<int_t<X0>>;
template<class Values> using front_t=type_t<front<Values>>;
template<class Values> constexpr front_t<Values> front_v = ;
template<class Values, size_t I>
struct get:tag<front_t< after_t<Values, I> >> ;
template<class Values, size_t I> using get_t = type_t<get<Values, I>>;
template<class Values, size_t I> constexpr get_t<Values, I> get_v = ;
template<class Values>
struct length;
template<int...Xs>
struct length<values<Xs...>>:tag<index_t<sizeof...(Xs)>> ;
template<class Values> using length_t = type_t<length<Values>>;
template<class Values> constexpr length_t<Values> length_v = ;
template<class Values> using front_half_t = before_t< Values, length_v<Values>/2 >;
template<class Values> constexpr front_half_t<Values> front_half_v = ;
template<class Values> using back_half_t = after_t< Values, length_v<Values>/2 >;
template<class Values> constexpr back_half_t<Values> back_half_v = ;
template<class Lhs, class Rhs>
struct least : tag< std::conditional_t< (Lhs<Rhs), Lhs, Rhs > > ;
template<class Lhs, class Rhs> using least_t = type_t<least<Lhs, Rhs>>;
template<class Lhs, class Rhs>
struct most : tag< std::conditional_t< (Lhs>Rhs), Lhs, Rhs > > ;
template<class Lhs, class Rhs> using most_t = type_t<most<Lhs, Rhs>>;
template<class Values>
struct pivot ;
template<int X0, int X1>
struct pivot<values<X0, X1>>: tag< most_t< int_t<X0>, int_t<X1> > > ;
template<class Values> using pivot_t = type_t<pivot<Values>>;
template<class Values> constexpr pivot_t<Values> pivot_v = ;
template<int P>
constexpr values<> lower_split( int_t<P>, values<> ) ; }
template<int P, int X0>
constexpr std::conditional_t< (X0<P), values<X0>, values<> > lower_split( int_t<P>, values<X0> ) ; }
template<int P, int X0, int X1, int...Xs >
constexpr auto lower_split( int_t<P>, values<X0, X1, Xs...> )
-> append_t<
decltype(lower_split( int_v<P>, front_half_v<values<X0, X1, Xs...>> )),
decltype(lower_split( int_v<P>, back_half_v<values<X0, X1, Xs...>> ))
>; }
template<int P>
constexpr values<> upper_split( int_t<P>, values<> ) ; }
template<int P, int X0>
constexpr std::conditional_t< (X0>P), values<X0>, values<> > upper_split( int_t<P>, values<X0> ) ; }
template<int P, int X0, int X1, int...Xs>
constexpr auto upper_split( int_t<P>, values<X0, X1, Xs...> )
-> append_t<
decltype(upper_split( int_v<P>, front_half_v<values<X0, X1, Xs...>> )),
decltype(upper_split( int_v<P>, back_half_v<values<X0, X1, Xs...>> ))
>; }
template<int P>
constexpr values<> middle_split( int_t<P>, values<> ) ; }
template<int P, int X0>
constexpr std::conditional_t< (X0==P), values<X0>, values<> > middle_split( int_t<P>, values<X0> ) ; }
template<int P, int X0, int X1, int...Xs>
constexpr auto middle_split( int_t<P>, values<X0, X1, Xs...> )
-> append_t<
decltype(middle_split( int_v<P>, front_half_v<values<X0, X1, Xs...>> )),
decltype(middle_split( int_v<P>, back_half_v<values<X0, X1, Xs...>> ))
>; }
template<class Values>
using lower_split_t = decltype(lower_split( pivot_v<Values>, Values ) );
template<class Values> constexpr lower_split_t<Values> lower_split_v = ;
template<class Values>
using upper_split_t = decltype(upper_split( pivot_v<Values>, Values ) );
template<class Values> constexpr upper_split_t<Values> upper_split_v = ;
template<class Values>
using middle_split_t = decltype(middle_split( pivot_v<Values>, Values ) );
template<class Values> constexpr middle_split_t<Values> middle_split_v = ;
constexpr values<> simple_merge_sort( values<> ) ; }
template<int X>
constexpr values<X> simple_merge_sort( values<X> ) ; }
template<class Values>
using simple_merge_sort_t = decltype( simple_merge_sort( Values ) );
template<class Values>
constexpr simple_merge_sort_t<Values> simple_merge_sort_v = ;
template<int X0, int X1, int...Xs>
constexpr auto simple_merge_sort( values<X0, X1, Xs...> )
->
simple_merge_t<
simple_merge_t<
simple_merge_sort_t<lower_split_t<values<X0, X1, Xs...>>>, simple_merge_sort_t<upper_split_t<values<X0, X1, Xs...>>>
>,
middle_split_t<values<X0, X1, Xs...>>
>
; }
template<class Values>constexpr Values cross_add( Values ) ; }
template<class Values>constexpr values<> cross_add( values<>, Values ) ; }
template<int A0, int...B>constexpr values<(B+A0)...> cross_add( values<A0>, values<B...> ) ; }
template<int A0, int A1, int...A, int...B>
constexpr auto cross_add( values<A0, A1, A...>, values<B...>)
-> append_t<
decltype(cross_add( front_half_v<values<A0, A1, A...>>, values_v<B...> ) ),
decltype(cross_add( back_half_v<values<A0, A1, A...>>, values_v<B...> ) )
> ; }
template<class V0, class V1, class V2, class... Vs>
constexpr auto cross_add( V0, V1, V2, Vs... )
-> decltype(
cross_add( cross_add( V0, V1 ), V2, Vs... )
) ; }
template<class...Vs>
using cross_add_t = decltype( cross_add(Vs...) );
template<class...Vs>
constexpr cross_add_t<Vs...> cross_add_v = ;
template<int X, int...Xs>
constexpr values<(X*Xs)...> scale( int_t<X>, values<Xs...> ) ; }
template<class X, class Xs>
using scale_t = decltype( scale(X, Xs) );
template<class X, class Xs> constexpr scale_t<X,Xs> scale_v = ;
template<int X0, int...Xs> struct generate_values : generate_values<X0-1, X0-1, Xs...> ;
template<int...Xs> struct generate_values<0,Xs...>:tag<values<Xs...>>;
template<int X0> using generate_values_t = type_t<generate_values<X0>>;
一个三数中值编译时归并排序和叉积生成器。我可以通过努力大幅减少行数。
使用
constexpr std::array
可能比上述纯类型解决方案更快。