home
***
CD-ROM
|
disk
|
FTP
|
other
***
search
/
PC World Komputer 1998 May
/
Pcwk5b98.iso
/
Borland
/
Cplus45
/
BC45
/
OWL1.PAK
/
TSORTCOL.CPP
< prev
next >
Wrap
Text File
|
1995-08-29
|
2KB
|
74 lines
// Borland C++ - (C) Copyright 1992 by Borland International
/*------------------------------------------------------------*/
/* filename - tsortcol.cpp */
/* */
/* function(s) */
/* TNSSortedCollection member functions */
/*------------------------------------------------------------*/
#if !defined( __OBJECT_H )
#include <object.h>
#endif // __OBJECT_H
#if !defined( __TCOLLECT_H )
#include <tcollect.h>
#endif // __TCOLLECT_H
ccIndex TNSSortedCollection::indexOf(void *item)
{
ccIndex i;
if( search( keyOf(item), i ) == 0 )
return ccNotFound;
else
{
if( duplicates )
{
while( i < count && item != items[i] )
i++;
}
if( i < count )
return i;
else
return ccNotFound;
}
}
ccIndex TNSSortedCollection::insert( void *item )
{
ccIndex i;
if( search( keyOf(item), i ) == 0 || duplicates ) // order dependency!
atInsert( i, item ); // must do Search
// before calling
// AtInsert
return i;
}
Boolean TNSSortedCollection::search( void *key, ccIndex& index )
{
ccIndex l = 0;
ccIndex h = count - 1;
Boolean res = False;
while( l <= h )
{
ccIndex i = (l + h) >> 1;
ccIndex c = compare( keyOf( items[i] ), key );
if( c < 0 )
l = i + 1;
else
{
h = i - 1;
if( c == 0 )
{
res = True;
if( !duplicates )
l = i;
}
}
}
index = l;
return res;
}