QuickIndex.h
00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018 #ifndef __QUICKINDEX_H__
00019 #define __QUICKINDEX_H__
00020
00021 #include "MathVector.h"
00022 #include "StringArray.h"
00023 #include "IntArray.h"
00024 #include "StringMap.h"
00025
00026 class QuickIndex : public IntArray
00027 {
00028 public:
00029 QuickIndex();
00030 QuickIndex(const IntArray & source_data)
00031 {
00032 Index(source_data);
00033 }
00034 QuickIndex(const StringArray & source_data)
00035 {
00036 Index(source_data);
00037 }
00038 QuickIndex(const Vector & source_data)
00039 {
00040 Index(source_data);
00041 }
00042
00043 void Index(const IntArray & source_data);
00044 void Index(const StringArray & source_data);
00045 void Index(const Vector & source_data);
00046 void IndexCounts(const StringIntMap & source_data);
00047
00048 private:
00049 const void * source;
00050 int datatype;
00051
00052 bool IsBefore(int i, int j);
00053 void Sort();
00054 };
00055
00056 #endif
00057