doc_splay_set.cpp

来自「Boost provides free peer-reviewed portab」· C++ 代码 · 共 94 行

CPP
94
字号
///////////////////////////////////////////////////////////////////////////////// (C) Copyright Ion Gaztanaga  2006-2007//// Distributed under the Boost Software License, Version 1.0.//    (See accompanying file LICENSE_1_0.txt or copy at//          http://www.boost.org/LICENSE_1_0.txt)//// See http://www.boost.org/libs/intrusive for documentation./////////////////////////////////////////////////////////////////////////////////[doc_splay_set_code#include <boost/intrusive/splay_set.hpp>#include <boost/intrusive/bs_set_hook.hpp>#include <vector>#include <algorithm>using namespace boost::intrusive;class MyClass   : public splay_set_base_hook<>   //This is an splay tree base hook   , public bs_set_base_hook<>      //This is a binary search tree base hook         {   int int_;   public:   //This is a member hook   splay_set_member_hook<> member_hook_;   MyClass(int i)      :  int_(i)      {}   friend bool operator< (const MyClass &a, const MyClass &b)      {  return a.int_ < b.int_;  }   friend bool operator> (const MyClass &a, const MyClass &b)      {  return a.int_ > b.int_;  }   friend bool operator== (const MyClass &a, const MyClass &b)      {  return a.int_ < b.int_;  }};//Define a set using the base hook that will store values in reverse ordertypedef splay_set< MyClass, compare<std::greater<MyClass> > >     BaseSplaySet;//Define a set using the binary search tree hooktypedef splay_set< MyClass, base_hook<bs_set_base_hook<> > >      BaseBsSplaySet;//Define an multiset using the member hooktypedef member_hook<MyClass, splay_set_member_hook<>, &MyClass::member_hook_> MemberOption;typedef splay_multiset< MyClass, MemberOption>   MemberSplayMultiset;int main(){   typedef std::vector<MyClass>::iterator VectIt;   typedef std::vector<MyClass>::reverse_iterator VectRit;   //Create several MyClass objects, each one with a different value   std::vector<MyClass> values;   for(int i = 0; i < 100; ++i)  values.push_back(MyClass(i));   BaseSplaySet   baseset;   BaseBsSplaySet bsbaseset;   MemberSplayMultiset membermultiset;   //Insert values in the container   for(VectIt it(values.begin()), itend(values.end()); it != itend; ++it){      baseset.insert(*it);      bsbaseset.insert(*it);      membermultiset.insert(*it);   }   //Now test sets   {      BaseSplaySet::reverse_iterator rbit(baseset.rbegin()), rbitend(baseset.rend());      BaseBsSplaySet::iterator bsit(bsbaseset.begin()), bsitend(bsbaseset.end());      MemberSplayMultiset::iterator mit(membermultiset.begin()), mitend(membermultiset.end());      VectIt it(values.begin()), itend(values.end());      //Test the objects inserted in the base hook set      for(; it != itend; ++it, ++rbit){         if(&*rbit != &*it)   return 1;      }      //Test the objects inserted in member and binary search hook sets      for(it = values.begin(); it != itend; ++it, ++bsit, ++mit){         if(&*bsit != &*it)   return 1;         if(&*mit != &*it)    return 1;      }   }   return 0;}//]

⌨️ 快捷键说明

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