⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 sort_impl.hpp

📁 boost库提供标准的C++ API 配合dev c++使用,功能更加强大
💻 HPP
字号:
//-----------------------------------------------------------------------------
// boost mpl/aux_/sort_impl.hpp header file
// See http://www.boost.org for updates, documentation, and revision history.
//-----------------------------------------------------------------------------
//
// Copyright (c) 2002-2003
// Eric Friedman
//
// Permission to use, copy, modify, distribute and sell this software
// and its documentation for any purpose is hereby granted without fee, 
// provided that the above copyright notice appears in all copies and 
// that both the copyright notice and this permission notice appear in 
// supporting documentation. No representations are made about the 
// suitability of this software for any purpose. It is provided "as is" 
// without express or implied warranty.

#ifndef BOOST_MPL_AUX_SORT_IMPL_HPP_INCLUDED
#define BOOST_MPL_AUX_SORT_IMPL_HPP_INCLUDED

#include "boost/mpl/aux_/select1st_wknd.hpp"
#include "boost/mpl/aux_/select2nd_wknd.hpp"
#include "boost/mpl/apply.hpp"
#include "boost/mpl/apply_if.hpp"
#include "boost/mpl/copy_backward.hpp"
#include "boost/mpl/empty.hpp"
#include "boost/mpl/front.hpp"
#include "boost/mpl/identity.hpp"
#include "boost/mpl/partition.hpp"
#include "boost/mpl/pop_front.hpp"
#include "boost/mpl/push_front.hpp"
#include "boost/mpl/aux_/traits_lambda_spec.hpp"

namespace boost {
namespace mpl {

namespace aux {

template < typename Sequence, typename Predicate > struct quick_sort;

template <typename Predicate, typename Pivot>
struct quick_sort_pred
{
    template <typename T>
    struct apply
    {
        typedef typename apply2< Predicate, T, Pivot >::type
            type;
    };
};

template <typename Sequence, typename Predicate>
struct quick_sort_impl
{
private:

    typedef typename front<Sequence>::type pivot_;
    typedef typename pop_front<Sequence>::type seq_;

    typedef typename partition<
          seq_
        , protect< quick_sort_pred<Predicate,pivot_> >
        >::type partitioned;

    typedef typename quick_sort<
          typename BOOST_MPL_AUX_SELECT1ST_WKND(partitioned), Predicate
        >::type first_part;
    typedef typename quick_sort<
          typename BOOST_MPL_AUX_SELECT2ND_WKND(partitioned), Predicate
        >::type second_part;

public:

    typedef typename copy_backward<
          first_part
        , typename push_front< second_part,pivot_ >::type
        , push_front<_,_>
        >::type type;

};

template <typename Sequence, typename Predicate>
struct quick_sort
    : apply_if<
          empty<Sequence>
        , identity< Sequence >
        , quick_sort_impl< Sequence,Predicate >
        >
{
};

} // namespace aux

template< typename Tag >
struct sort_traits
{
    template< typename Sequence, typename Predicate >
    struct algorithm
    {
        typedef typename aux::quick_sort<
              Sequence, Predicate
            >::type type;
    };
};

BOOST_MPL_ALGORITM_TRAITS_LAMBDA_SPEC(2,sort_traits)

} // namespace mpl
} // namespace boost

#endif // BOOST_MPL_AUX_SORT_IMPL_HPP_INCLUDED

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -