data:image/s3,"s3://crabby-images/207c7/207c7b8b73e7113a4ecd3807a00df3d883d80d1a" alt=""
// SPECIFICATION FILE ( unsorted.h )
#include “ItemType.h”
class UnsortedType // declares a class data type
{
public : // 8 public member functions
void UnsortedType ( ) ;
bool IsFull ( ) const ;
int LengthIs ( ) const ; // returns length of list
void RetrieveItem ( ItemType& item, bool& found ) ;
void InsertItem ( ItemType item ) ;
void DeleteItem ( ItemType item ) ;
void ResetList ( );
void GetNextItem ( ItemType& item ) ;
private : // 3 private data members
int length ;
ItemType info[MAX_ITEMS] ;
int currentPos ;
} ;
// IMPLEMENTATION FILE ARRAY-BASED LIST ( unsorted.cpp )
#include “itemtype.h”
void UnsortedType::UnsortedType ( )
// Pre: None.
// Post: List is empty.
{
length = 0 ;
}
void UnsortedType::InsertItem ( ItemType item )
// Pre: List has been initialized. List is not full.
// item is not in list.
// Post: item is in the list.
{
info[length] = item ;
length++ ;
}
Before HSing inserted into list data:image/s3,"s3://crabby-images/bf156/bf156c481c5f73c8e14f5550700fc6a14e7f0fe7" alt=""
After HSing inserted into list
int UnsortedType::LengthIs ( ) const
// Pre: List has been inititalized.
// Post: Function value == ( number of elements in
// list ).
{
return length ;
}
bool UnsortedType::IsFull ( ) const
// Pre: List has been initialized.
// Post: Function value == ( list is full ).
{
return ( length == MAX_ITEMS ) ;
}
void UnsortedType::RetrieveItem ( ItemType& item, bool& found )
// Pre: Key member of item is initialized.
// Post: If found, item’s key matches an element’s key in the list
// and a copy of that element has been stored in item;
// otherwise, item is unchanged.
{ bool moreToSearch ;
int location = 0 ;
found = false ;
moreToSearch = ( location < length ) ;
while ( moreToSearch && !found )
{ switch ( item.ComparedTo( info[location] ) )
{ case LESS :
case GREATER : location++ ;
moreToSearch = ( location < length ) ;
case EQUAL : found = true ;
item = info[ location ] ;
break ;
}
}
}
Attemp to Retrieve "Ivan" from Listdata:image/s3,"s3://crabby-images/1045b/1045bf326913d57e121911e4368ddba32dfa078a" alt=""
data:image/s3,"s3://crabby-images/9154e/9154e7a69b70f58b43bf02da0ad5e3798e23ee98" alt=""
data:image/s3,"s3://crabby-images/d233b/d233bf60914ff4250be68d172c6450311cc73bd6" alt=""
data:image/s3,"s3://crabby-images/6901a/6901a0233a0c76e2b5b252eb86b68f6447bc4a14" alt=""
data:image/s3,"s3://crabby-images/2d981/2d981371f1a84e0c7beb3d96f41e0113c859fb60" alt=""
void UnsortedType::DeleteItem ( ItemType item )
// Pre: item’s key has been inititalized.
// An element in the list has a key that matches item’s.
// Post: No element in the list has a key that matches item’s.
{
int location = 0 ;
while (item.ComparedTo (info [location] ) != EQUAL )
location++;
// move last element into position where item was located
info [location] = info [length - 1 ] ;
length-- ;
}
Deleting Bradely from the List
data:image/s3,"s3://crabby-images/2db6a/2db6a6d395ba15884006f8ec36c2ccc0bd0aecc5" alt=""
void UnsortedType::ResetList ( )
// Pre: List has been inititalized.
// Post: Current position is prior to first element in list.
{
currentPos = -1 ;
}
void UnsortedType::GetNextItem ( ItemType& item )
// Pre: List has been initialized. Current position is defined.
// Element at current position is not last in list.
// Post: Current position is updated to next position.
// item is a copy of element at current position.
{
currentPos++ ;
item = info [currentPos] ;
}
|