Это куча, реализованная мной (для конкурса алгоритмов). Есть некоторые ошибки компиляции, из которых я не могу исправить ...
\Map_Heap.cpp|13|error: invalid use of non-static data member 'MapHeap<DT>::nv'|
\Map_Heap.cpp|19|error: from this location|
Код:
#include<cstdio>
#include<cstring>
const int HEAP_SIZE=10005;
template<class DT>
struct MapHeap
{
DT f[HEAP_SIZE+5];
int mp1[HEAP_SIZE+5];//val -> index
int mp2[HEAP_SIZE+5];//index -> val
int nv;///line 13
MapHeap():nv(0)
{
memset(mp1,-1,sizeof(mp1));
memset(mp2,-1,sizeof(mp2));
}
void print(int n=nv)//line 19
{
for(int i=1;i<=n;i++) printf("%d ",f[i]);
puts("");
for(int i=1;i<=n;i++) printf("%d ",mp1[i]);
puts("");
for(int i=1;i<=n;i++) printf("%d ",mp2[i]);
puts("");
}
};