1994-11-04 16:29:24 +00:00
|
|
|
|
|
|
|
#include <objects/objects.h>
|
|
|
|
|
|
|
|
#define N 20
|
1995-06-29 01:08:14 +00:00
|
|
|
#if (sun && __svr4__) || defined(__hpux) || defined(_SEQUENT_)
|
1994-11-04 16:29:24 +00:00
|
|
|
long lrand48();
|
|
|
|
#define random lrand48
|
|
|
|
#else
|
1996-02-13 15:43:30 +00:00
|
|
|
#if WIN32
|
|
|
|
#define random rand
|
|
|
|
#else
|
1994-11-04 16:29:24 +00:00
|
|
|
long random();
|
|
|
|
#endif
|
1996-02-13 15:43:30 +00:00
|
|
|
#endif
|
1994-11-04 16:29:24 +00:00
|
|
|
|
|
|
|
int main()
|
|
|
|
{
|
|
|
|
int i;
|
|
|
|
short s, s1, s2;
|
|
|
|
|
|
|
|
Heap* heap = [[Heap alloc] initWithType:"s"];
|
|
|
|
Array* array = [[Array alloc] initWithType:"s"];
|
|
|
|
|
|
|
|
for (i = 0; i < N; i++)
|
|
|
|
{
|
|
|
|
s = (short)random();
|
|
|
|
[heap addElement:s];
|
|
|
|
[array addElement:s];
|
|
|
|
}
|
|
|
|
[array sortContents];
|
|
|
|
|
|
|
|
for (i = 0; i < N; i++)
|
|
|
|
{
|
|
|
|
s1 = [heap removeFirstElement].short_int_u;
|
|
|
|
s2 = [array removeLastElement].short_int_u;
|
|
|
|
printf("(%d,%d) ", s1, s2);
|
|
|
|
if (s1 != s2)
|
|
|
|
exit(1);
|
|
|
|
}
|
|
|
|
printf("\n");
|
|
|
|
|
|
|
|
/* cause an error */
|
|
|
|
/* s = [heap elementAtIndex:999].short_int_u; */
|
|
|
|
|
1995-03-12 19:33:56 +00:00
|
|
|
[heap release];
|
1994-11-04 16:29:24 +00:00
|
|
|
exit(0);
|
|
|
|
}
|