mirror of
https://github.com/NGSolve/netgen.git
synced 2025-01-18 08:50:33 +05:00
71 lines
995 B
C++
71 lines
995 B
C++
|
#include <mystdlib.h>
|
||
|
#include <myadt.hpp>
|
||
|
|
||
|
|
||
|
namespace netgen
|
||
|
{
|
||
|
//using namespace netgen;
|
||
|
|
||
|
IndexSet :: IndexSet (int maxind)
|
||
|
{
|
||
|
SetMaxIndex (maxind);
|
||
|
}
|
||
|
|
||
|
IndexSet :: ~IndexSet ()
|
||
|
{
|
||
|
Clear();
|
||
|
}
|
||
|
|
||
|
|
||
|
void IndexSet :: SetMaxIndex (int maxind)
|
||
|
{
|
||
|
if (maxind > flags.Size())
|
||
|
{
|
||
|
flags.SetSize (2 * maxind);
|
||
|
flags.Clear();
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/*
|
||
|
int IndexSet :: IsIn (int ind) const
|
||
|
{
|
||
|
return flags.Test (ind);
|
||
|
}
|
||
|
*/
|
||
|
|
||
|
/*
|
||
|
void IndexSet :: Add (int ind)
|
||
|
{
|
||
|
if (ind > flags.Size())
|
||
|
{
|
||
|
cerr << "out of range" << endl;
|
||
|
exit (1);
|
||
|
}
|
||
|
|
||
|
if (!flags.Test(ind))
|
||
|
{
|
||
|
set.Append (ind);
|
||
|
flags.Set (ind);
|
||
|
}
|
||
|
}
|
||
|
*/
|
||
|
|
||
|
void IndexSet :: Del (int ind)
|
||
|
{
|
||
|
for (int i = 1; i <= set.Size(); i++)
|
||
|
if (set.Get(i) == ind)
|
||
|
{
|
||
|
set.DeleteElement (ind);
|
||
|
break;
|
||
|
}
|
||
|
flags.Clear (ind);
|
||
|
}
|
||
|
|
||
|
void IndexSet :: Clear ()
|
||
|
{
|
||
|
for (int i = 1; i <= set.Size(); i++)
|
||
|
flags.Clear (set.Get(i));
|
||
|
set.SetSize (0);
|
||
|
}
|
||
|
}
|