2 * Copyright 2002 Adrian Thurston <thurston@cs.queensu.ca>
5 /* This file is part of Aapl.
7 * Aapl is free software; you can redistribute it and/or modify it under the
8 * terms of the GNU Lesser General Public License as published by the Free
9 * Software Foundation; either version 2.1 of the License, or (at your option)
12 * Aapl is distributed in the hope that it will be useful, but WITHOUT ANY
13 * WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
14 * FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for
17 * You should have received a copy of the GNU Lesser General Public License
18 * along with Aapl; if not, write to the Free Software Foundation, Inc., 59
19 * Temple Place, Suite 330, Boston, MA 02111-1307 USA
22 #ifndef _AAPL_BUBBLESORT_H
23 #define _AAPL_BUBBLESORT_H
36 * \brief Bubble sort an array of data.
38 * BubbleSort can be used to sort any array of objects of type T provided a
39 * compare class is given. BubbleSort is in-place. It does not require any
42 * Objects are not made aware that they are being moved around in memory.
43 * Assignment operators, constructors and destructors are never invoked by the
46 * BubbleSort runs in O(n^2) time. It is most useful when sorting arrays that
47 * are nearly sorted. It is best when neighbouring pairs are out of place.
48 * BubbleSort is a stable sort, meaning that objects with the same key have
49 * their relative ordering preserved.
55 template <class T
, class Compare
> class BubbleSort
59 /* Sorting interface routine. */
60 void sort(T
*data
, long len
);
65 * \brief Bubble sort an array of data.
67 template <class T
, class Compare
> void BubbleSort
<T
,Compare
>::
68 sort(T
*data
, long len
)
71 for ( long pass
= 1; changed
&& pass
< len
; pass
++ ) {
73 for ( long i
= 0; i
< len
-pass
; i
++ ) {
74 /* Do we swap pos with the next one? */
75 if ( compare( data
[i
], data
[i
+1] ) > 0 ) {
78 /* Swap the two items. */
79 memcpy( tmp
, data
+i
, sizeof(T
) );
80 memcpy( data
+i
, data
+i
+1, sizeof(T
) );
81 memcpy( data
+i
+1, tmp
, sizeof(T
) );
83 /* Note that we made a change. */
94 #endif /* _AAPL_BUBBLESORT_H */