**THE SYMBOL TABLE ABSTRACT DATA TYPE**

We have all used a dictionary. and many of us have a word processor equipped with a limited dictionary. that is. a spelling checker. In this chapter. we consider the dictionary. as an ADT. Examples of dictionaries are found in many applications. including the spelling checker. the thesaurus. the data dictionary found in database management applications. and the symbol tables generated by loaders. assemblers. and compilers.

In computer science. we generally use the term symbol table rather than dictionary. when referring to the ADT. Viewed from this perspective. we define a symbol table as a set of name-attribute pairs. The characteristics of the name and attribute vary according to the application. For example. in a thesaurus. the name is a word. and the attribute is a list of synonyms for the word; in a symbol table for a compiler. the name is an identifier, and the attributes might include an initial value and a list of lines that use the

identifier.

Generally we want to perform the following. operations on a symbol table:

(1) determine if a particular name is in the table.

(2) retrieve the attributes of that name.

(3) modify the attributes of that name.

(4) insert a new name and its attributes.

(5) delete a name and its attributes.

ADT provides the complete specification of the symbol table ADT.

·Although ADT 8.1 lists several operations. there are only three basic operations on . symbol tables: searching, inserting, and deleting. Therefore, when choosing a symbol table representation, we must make sure that. we can implement these operations ·efficiently. For example, we could use the binary search tree introduced to represent a symbol table .. If our search tree contained II identifiers, the worst-case complexity for these operations would be 0(11). ·In Chapter 10 we introduce several refinements of the binary search tree data structure that reduce the lime per operation to O(log n). In this chapter we examine a technique for search, insert, and delete operations that has very good expected performance. The technique is referred to as hashing. Unlike search tree methods which rely on identifier comparisons to perform a search. hashing relies on a formula called the hash function. We divide our discussion of hashing into two parts: static hashing and dynamic hashing.

**STATIC HASHING**

**Hash Tables**

In static hashing the identifiers are stored in a fixed-size table called the hash table. The address or location of an identifier. x. is obtained by computing some arithmetic function. h. of x. h (x) gives the address of x in the table. This address will be referred to as the hash or home address of n1. The memory available to maintain the symbol table is assumed to be sequential. This memory is referred to as the hash table. ht, The-hash table is Partitioned into b buckets. ht [0]. . .. ht [b – 1]. Each bucket is capable of holding 5 records. Thus. a bucket is said to consist of s slots. each slot being large enough to hold one record. Usually s = I. and each bucket can hold exactly one record. A hash function. h (z), is used to perform an identifier transformation on x. h (x) maps the set of possible identifiers onto the integers 0 through b – I. If we limit the identifiers to be at most six characters long. with the first one being a letter and the remaining either letters or decimal digits. then there are

distinct-possible values for x.

Any-reasonable application. however. uses only a very small fraction of these.

**Definition:** The identifier density of a hash table is the ratio n/T, where n is the number of identifiers in the table and T is the total number of possible identifiers. The loading density or coding factor of a hash table is a = n/(sb).

Since the number of identifiers. n. in use is usually several orders of magnitude less than the total number of possible identifiers. T, the number of buckets. b. in the hash table is also much less than T. Therefore. the hash function h must map several different identifiers into the same bucket Two identifiers. I J. and 12• are said to be synonyms with respect to ” if” (/ J) “(/2)’ Distinct synonyms are entered into the same bucket as long wall the I slots in that bucket have not been used. An overflow is said to occur when a new identifier I is mapped Or hashed by” into a full bucket. A collision occurs when two nonidentical identifier are hashed into the same bucket. When the bucket size 5 is 1. collisions and overflows occur simultaneously.

**Example**

Note that GA and G are in the same bucket and each. bucket has two slots. Similarly. the synonyms A and A2 are in the same bucket. The next identifier. AI. hashes into the bucket ht [0]. This bucket is full and a search of the bucket indicates that Al is not in the bucket. An overflow has now occurred. Where in the table should A 1 be entered so that it may be retrieved when needed?

When no overflows occur. the time required to enter or search for identifiers using hashing depends only on the time required to compute the hash function h and the time to search one bucket. Since the bucket size. s, is usually small (for internal tables s is usually 1) the search for an identifier within a bucket is carried out using a sequential search, The time is independent of n.

The hash function of Example is not well suited for the application we have in mind because of the very large number of collisions and resulting overflows that occur. This is so because it is not unusual to find programs in which many of the variables begin with the same letter. Ideally, we would like to choose a function h that is both easy to compute and results in very few collisions. Since the ratio b/T is usually very small. it is impossible to avoid collisions altogether.

In summary. hashing schemes perform an identifier transformation through the use of a hash function h. It is desirable to choose a function h that is easy to compute and also minimizes the number of collisions. Since the size of the identifier space. T. is usually several orders of magnitude larger than the number of buckets. b. and s is small. overflows necessarily occur. Hence. a mechanism to handle overflows is also needed.