ABSTRACT DATA TYPES
LESSON 01
                       Learning outcome
• Describe what a data type is
• Describe what abstraction is
• Define abstract data types and describe their uses
                                 Data Types
•   A data type provided in a programming language means that such type is built into
    the language.
•   Most programming languages provide simple data types for representing basic
    information.
E.g.:
•   1. An integer may represent the total number of savings accounts in a bank
•   2. A real number might represent the amount of money available in a particular
    savings account
                               Data types cont.
• The fore mentioned datatypes are primitive data types.
• Consider Java
   •   Eight primitive data types are provided or defined in Java viz. boolean, char, byte,
       short, int, long, float and double.
• A strongly typed programming language such as Java requires that you
  explicitly declare variables before you can store a particular data type in
  them.
                          Data types cont.
• Programming languages usually provide ways for a programmer to combine
  primitive types into more complex structures, which can capture
  relationships among the individual data items.
• For example, a programmer can combine two primitive integer values to
  represent a point in the x-y plane.
• A data type composed of multiple elements is called a composite data
  type.
                                     Abstraction
• An abstraction is a separation of relevant from the irrelevant; more
  specifically, it is focusing on the general concepts that apply to different but
  concrete instances.
• Abstract concept
   •   two plus three is equal to five (2 + 3 = 5).
• Knowingly or unknowingly you have used the above abstract concept to
  deduce results like two cars plus three cars is equal to five cars and two trees
  plus three trees is equal to five trees.
                         Abstraction cont.
• Rule of addition applies to cars and to trees is completely irrelevant to the
  rule itself.
• A single abstraction can be the base of many instances and an abstraction
  usually evolves after having experienced some of its real instances but it is
  not a must.
                     Abstract Data Types
• The manner or the method in which data types are implemented is
  irrelevant to how they are used in client programs.
Abstract Data types
• Just what is an integer?
• Integers are physically represented in different ways on different
  computers.
   •   In the memory of one machine, an integer may be a binary-coded decimal.
   •   In a second machine, it may be a sign and-magnitude binary.
   •   In a third one, it may be represented in two’s-complement binary notation.
                  Abstract Data types cont.
• The way that integers are physically represented determines how the
  computer manipulates them.
• As a Java programmer, however, you do not usually get involved at this
  level; you simply use integers.
• All you need to know is how to declare an int type variable and what
  operations are allowed on integers: assignment, addition, subtraction,
  multiplication, division, and modulo arithmetic
                         Abstract Data types cont.
•   Consider the statement
     distance = rate * time;
•   The concept of multiplication does not depend on whether the operands are, say, integers
    or real numbers, despite the fact that integer multiplication and floating-point
    multiplication may be implemented in very different ways on the same computer.
•   Computers would not be very popular if every time we wanted to multiply two numbers we
    had to get down to the machine-representation level.
•   Nevertheless, we do not have to: Java has provided the int data type for us, hiding all the
    implementation details and giving us just the information we need to create and
    manipulate data of this type.
•   Java has encapsulated integers for us.
                       Data Encapsulation
• Data encapsulation means that the physical representation of a program’s
  data is hidden by the language.
• The programmer using the data does not see the underlying
  implementation, but deals with the data only in terms of its logical picture -
  its abstraction.
                                    Operations
• Operations must be provided to allow the programmer to create, access,
  and change the data.
   •   Create variables of type int using declarations
   •   Assign values to these integer variables
   •   Perform arithmetic operations on them using +, -, *, /, and %.
A black box representing an integer data type
                 Abstract data types cont.
• The advantages of dealing with a logical data abstraction: you can think of
  the data and the operations in a logical sense and can consider their use
  without having to worry about implementation details.
• Abstract data type (ADT) is a data type whose properties (domain and
  operations) are specified independently of any particular implementation
              Two goals with abstract design
1.   Reduce complexity through abstraction and
2.   Protect our data through encapsulation
                    Abstract data types cont.
• All the Java built-in (primitive) types are ADTs
   •   Meaning that a Java programmer can declare variables of those types without
       understanding the underlying implementation.
• The programmer can initialize, modify, and access the information held by
  the variables using the provided operations.
                   Abstract data types cont.
• An ADT gives us the opportunity to focus entirely on the behavior of the
  data type without having to worry about its implementation and thus lead
  to providing a precise definition of such data type.
• By doing so, the essential differences existing among data types can be
  distinguished.
                               Example
• Let us consider two data types : Bag and Set.
• We can define their ADTs as follows,
ADT bag
ADT set
                                 Example cont.
• Both are containers with only a single difference between them.
   •   Bag may contain duplicate elements
   •   Set will not allow duplicate objects.
• Apart from that, they are both unstructured and unordered collections.
                                Example cont.
• The two ADTs identify two transformer methods (mutator operations) viz.
  add and remove and four observer methods (accessor operations) namely
  contains, getFirst, getNext and size.
   •   Transformer (Mutator) – is a method (operation) that changes the internal state of the
       object.
   •   Observer (Accessor) – is a method (operation) that returns an observation on the state
       of the object.
                       Observer methods
• The easiest way to identify observer methods is by their postconditions that
  the objects, containers in this instance remain unchanged.
           Observer methods in Bag and Set
• If you look carefully, you will be able to observe that the four observer
  methods are the same for our two ADTs Bag and Set.
• Only the two transformers add and remove are different, let us see how.
              Transformers in Bag and Set
• How add method in set is different from bag?
• How remove method in set is different from bag?
• One of the advantages of ADTs is that they can be used in algorithms.
An algorithm that removes all instances of an
         object/element from a bag.
Input: a Bag b; an object x
Output: the number of objects removed.
Postcondition: the Bag b contains no x objects.
1. Let n be the integer 0.
2. If b.contains(x) is false, then return n.
3. b.remove(x).
4. Add 1 to n.
5. Go to step 2.
                                 Abstraction
• We were able to completely specify the above algorithm without having to
  worry about the implementation of the operations contains and remove.
• This is the power of an ADT. You only have to know what you can do with the
  data type
   •   Example: what you can do with a bag?
                     Concrete Data Types
• A concrete data type is an implementation of an ADT in a particular
  programming language from which real objects can be created and
  manipulated of that data type.
• In Java, the realization of the concrete data type would be as follows
                                In Java
• With Java, an ADT can be translated into an interface, which can then be
  implemented as a class.
• Let us now see how our Bag ADT can be translated or realized in Java.
        An Interface for our Bag ADT
public interface Bag {
public void add(Object object);
public Boolean contains(Object
object);
public Object getFirst();
public Object getNext();
public boolean remove(Object object);
public int size();
}
                                 Overview
• The interface gives an overview of the nature of the bag. It describes the
  method prototypes.
For example
• The remove method takes an Object as an argument and will return a
  Boolean value as the output.
• An interface does not contain method implementations.
• In order to create a bag object we have to first define a bag class that
  implements the bag interface.
• simple array data structure is used to implement the bag interface.
Creating a bag object
Bag bagOfFruits = new ArrayBag();
                                Adding items
                       bagOfFruits.add(“Apple”);
                       bagOfFruits.add(“Lemon”);
                       bagOfFruits.add(“Avocado”);
• Then you can add elements or objects to your bagOfFruits with the add
  method.
   •   You can add an apple, a lemon and an avocado to the bag with the above code
       segment
                          Methods of Bag
• After adding objects, you can check whether an object is inside our bag.
• The method contains will check whether a particular object is contained
  within the bag and if the object provided as the argument is in the array,
  bagOfFruits the method contains will return true and if not it will return
  false.
If we assume that there is at least one lemon and no oranges in the bag.
            bagOfFruits.contains(“Lemon”); // will
            return true
            bagOfFruits.contains(“Orange”); // will
            return false
                     getFirst and getNext
• The getFirst method will output the first object in the array
• The getNext method will fetch the subsequent items of the array.
                             Remove method
• The remove method will eliminate a given object from the array.
• The method will search through the array starting from the first element
  and if a match is found it will be removed by shifting all the array elements
  that follow, back one position.
• Size of the array will also be decreased by one.
   •   To achieve this we use the predefined method array copy provided in Java.
• The method takes into consideration five arguments in the following order.
                          Remove method
arraycopy(Object src, int srcPos, Object dest, int destPos, int length)
                          Remove method
• The two Object arguments src and dest specify the array to copy from and
  the array to copy to.
• The three int arguments srcPos, destPos and length specify the starting
  position in the source array, the starting position in the destination array,
  and the number of array elements to copy, respectively.
                                  Remove method
for(int i = 0; i < size; i++) {
    if(objects[i] == object) {
         System.arraycopy(objects, i + 1, objects, i, size - i -1);
         objects[--size] = null;
         return true;
    }
}
                               Test driver class
• To check whether our Bag ADT and its ArrayBag implementation are
  working.
• In the test program,
   •   First create a reference to Bag objects and then add some fruits.
   •   Next use the methods to observe and manipulate our bag.