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 "StringHash.h"
00024 #include "IntArray.h"
00025 #include "StringMap.h"
00026
00027 class QuickIndex : public IntArray
00028 {
00029 public:
00030 QuickIndex();
00031 QuickIndex(const IntArray & source_data)
00032 {
00033 Index(source_data);
00034 }
00035 QuickIndex(const StringArray & source_data)
00036 {
00037 Index(source_data);
00038 }
00039 QuickIndex(const Vector & source_data)
00040 {
00041 Index(source_data);
00042 }
00043
00044 void Index(const IntArray & source_data);
00045 void Index(const StringArray & source_data);
00046 void Index(const Vector & source_data);
00047 void IndexCounts(const StringIntMap & source_data);
00048 void IndexCounts(const StringIntHash & source_data);
00049
00050 private:
00051 const void * source;
00052 int datatype;
00053
00054 bool IsBefore(int i, int j);
00055 void Sort();
00056 };
00057
00058 #endif
00059