Main Page   Namespace List   Class Hierarchy   Compound List   File List   Namespace Members   Compound Members  

bubble_sort_algorithm.hh

00001 /*
00002 *  Name:      bubble_sort_algorithm.hh
00003 *  Author:    Rafael Jesus Alcantara Perez
00004 *  Summary:   Bubble sort algorithm
00005 *  Date:      $Date: 2003/04/14 00:18:35 $
00006 *  Revision:  $Revision: 1.1 $
00007 *
00008 *  Copyright (C) 1994-2002  Rafael Jesus Alcantara Perez <rafa@dedalo-ing.com>
00009 *
00010 *  This program is free software; you can redistribute it and/or modify
00011 *  it under the terms of the GNU General Public License as published by
00012 *  the Free Software Foundation; either version 2 of the License, or
00013 *  (at your option) any later version.
00014 *
00015 *  This program is distributed in the hope that it will be useful,
00016 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
00017 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
00018 *  GNU General Public License for more details.
00019 *
00020 *  You should have received a copy of the GNU General Public License
00021 *  along with this program; if not, write to the Free Software
00022 *  Foundation, Inc., 59 Temple Place, Suite 330, Boston,
00023 *  MA 02111-1307, USA.
00024 */
00025 
00026 #ifndef _MPCL_UTIL_STRATEGY_BUBBLE_SORT_ALGORITHM__
00027 #define _MPCL_UTIL_STRATEGY_BUBBLE_SORT_ALGORITHM__
00028 
00029 #include "sort_algorithm.hh"
00030 
00031 
00033 namespace mpcl
00034 {
00035 
00037   namespace util
00038   {
00039 
00041     namespace strategy
00042     {
00043 
00055       template <typename TSequence>
00056       class TBubbleSortAlgorithm : public ISortAlgorithm<TSequence>
00057       {
00058 
00059         public:
00060 
00062           typedef
00063             typename ISortAlgorithm<TSequence>::iterator
00064             iterator;
00065 
00067           typedef
00068             typename ISortAlgorithm<TSequence>::const_iterator
00069             const_iterator;
00070 
00071 
00072         public:
00073 
00079           void execute (TSequence& rtSOURCE_SEQUENCE)
00080           {
00081 
00082             if ( rtSOURCE_SEQUENCE.size() > 1 )
00083             {
00084               iterator         J;
00085               iterator         I     = rtSOURCE_SEQUENCE.begin();
00086               const_iterator   ktEnd = rtSOURCE_SEQUENCE.end();
00087 
00088               for (; ( I != ktEnd ) ;++I)
00089               {
00090                 for (J = I + 1; ( J != ktEnd ) ;++J)
00091                 {
00092                   if ( *I > *J )
00093                   {
00094                     swap (*I, *J);
00095                   }
00096                 }
00097               }
00098             }
00099 
00100           }  // execute()
00101 
00102       };  // class TBubbleSortAlgorithm
00103 
00104     }  // namespace strategy
00105 
00106   }  // namespace util
00107 
00108 }  // namespace mpcl
00109 
00110 
00111 #endif  // not _MPCL_UTIL_STRATEGY_BUBBLE_SORT_ALGORITHM__

Generated on Mon Oct 13 02:35:22 2003 for MPCL by doxygen1.2.18