0% found this document useful (0 votes)
58 views16 pages

Class 1 Abstract Data Types

1. An abstract data type (ADT) defines the essential operations on a data structure without specifying how those operations are implemented. This allows for abstraction and data structure independence. 2. Common ADTs include lists, stacks, and queues. Each defines essential functions like insert, remove, peek without specifying the underlying implementation. 3. ADTs provide advantages like encapsulation, abstraction, modularity and information hiding while disadvantages can include overhead, complexity, and limited flexibility.

Uploaded by

Ramesh L
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PPTX, PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
58 views16 pages

Class 1 Abstract Data Types

1. An abstract data type (ADT) defines the essential operations on a data structure without specifying how those operations are implemented. This allows for abstraction and data structure independence. 2. Common ADTs include lists, stacks, and queues. Each defines essential functions like insert, remove, peek without specifying the underlying implementation. 3. ADTs provide advantages like encapsulation, abstraction, modularity and information hiding while disadvantages can include overhead, complexity, and limited flexibility.

Uploaded by

Ramesh L
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PPTX, PDF, TXT or read online on Scribd
You are on page 1/ 16

ABSTRACT DATA TYPES

Learning Objectives
 To Learn the concept of ADT’s
 Understand how ADT’s is working
 Demonstrate the ADT’s
 Apply the ADTS
 To Understand Features, Advantages and
Dis advantages of ADT’s
INTRODUCTION
 Abstract Data type (ADT) is a type (or class) for
objects whose behavior is defined by a set of values
and a set of operations. The definition of ADT only
mentions what operations are to be performed but
not how these operations will be implemented.

 It does not specify how data will be organized in


memory and what algorithms will be used for
implementing the operations. It is called “abstract”
because it gives an implementation-independent
view.
The process of providing only the essentials and
hiding the details is known as abstraction. 
Examples
 List ADT, 
 Stack ADT, 
 Queue ADT.
List ADT
List ADT
 The data is generally stored in key sequence in a list which has a head
structure consisting of count, pointers and address of compare function needed to
compare the data in the list.
 The data node contains the pointer to a data structure and a self-referential
pointer which points to the next node in the list.
 The List ADT Functions is given below:
 get() – Return an element from the list at any given position.
 insert() – Insert an element at any position of the list.
 remove() – Remove the first occurrence of any element from a non-empty list.
 removeAt() – Remove the element at a specified location from a non-empty
list.
 replace() – Replace an element at any position by another element.
 size() – Return the number of elements in the list.
 isEmpty() – Return true if the list is empty, otherwise return false.
 isFull() – Return true if the list is full, otherwise return false.
Stack ADT
Stack ADT
 In Stack ADT Implementation instead of data being stored in each node, the
pointer to data is stored.
 The program allocates memory for the data and address is passed to the stack
ADT.
 The head node and the data nodes are encapsulated in the ADT. The calling
function can only see the pointer to the stack.
 The stack head structure also contains a pointer to top and count of number of
entries currently in stack.
 push() – Insert an element at one end of the stack called top.
 pop() – Remove and return the element at the top of the stack, if it is not
empty.
 peek() – Return the element at the top of the stack without removing it, if the
stack is not empty.
 size() – Return the number of elements in the stack.
 isEmpty() – Return true if the stack is empty, otherwise return false.
 isFull() – Return true if the stack is full, otherwise return false.
Queue ADT
Queue ADT
 The queue abstract data type (ADT) follows the basic design of the
stack abstract data type.
 Each node contains a void pointer to the data and the link pointer to
the next element in the queue. The program’s responsibility is to
allocate memory for storing the data.
 enqueue() – Insert an element at the end of the queue.
 dequeue() – Remove and return the first element of the queue, if the
queue is not empty.
 peek() – Return the element of the queue without removing it, if the
queue is not empty.
 size() – Return the number of elements in the queue.
 isEmpty() – Return true if the queue is empty, otherwise return false.
 isFull() – Return true if the queue is full, otherwise return false.
Features of ADT:

 Abstract data types (ADTs) are a way of encapsulating


data and operations on that data into a single unit.
Some of the key features of ADTs include:

 Abstraction: The user does not need to know the


implementation of the data structure only essentials are
provided.
 Better Conceptualization: ADT gives us a better
conceptualization of the real world.
 Robust: The program is robust and has the ability to
catch errors.
Features of ADT:
-Contd..,
 Encapsulation: ADTs hide the internal details of the data and provide a
public interface for users to interact with the data. This allows for easier
maintenance and modification of the data structure.
 Data Abstraction: ADTs provide a level of abstraction from the
implementation details of the data. Users only need to know the operations
that can be performed on the data, not how those operations are
implemented.
 Data Structure Independence: ADTs can be implemented using different
data structures, such as arrays or linked lists, without affecting the
functionality of the ADT.
 Information Hiding: ADTs can protect the integrity of the data by
allowing access only to authorized users and operations. This helps
prevent errors and misuse of the data.
 Modularity: ADTs can be combined with other ADTs to form larger, more
complex data structures. This allows for greater flexibility and modularity
in programming.
Advantages:

 Encapsulation: ADTs provide a way to encapsulate data and


operations into a single unit, making it easier to manage and
modify the data structure.
 Abstraction: ADTs allow users to work with data structures
without having to know the implementation details, which can
simplify programming and reduce errors.
 Data Structure Independence: ADTs can be implemented using
different data structures, which can make it easier to adapt to
changing needs and requirements.
 Information Hiding: ADTs can protect the integrity of data by
controlling access and preventing unauthorized modifications.
 Modularity: ADTs can be combined with other ADTs to form
more complex data structures, which can increase flexibility and
modularity in programming.
Disadvantages:

 Overhead: Implementing ADTs can add overhead in terms


of memory and processing, which can affect performance.
 Complexity: ADTs can be complex to implement, especially
for large and complex data structures.
 Learning Curve: Using ADTs requires knowledge of their
implementation and usage, which can take time and effort to
learn.
 Limited Flexibility: Some ADTs may be limited in their
functionality or may not be suitable for all types of data
structures.
 Cost: Implementing ADTs may require additional resources
and investment, which can increase the cost of development.
Questions
 What is ADT’S?
 List out the features, Advantages and
disadvantages of ADT’s

You might also like