Presentation is loading. Please wait.

Presentation is loading. Please wait.

Lecture 4 Abstract Data Types (ADT). Usual Data Types Integer, Double, Boolean You do not know the implementation of these. There are some operations.

Similar presentations


Presentation on theme: "Lecture 4 Abstract Data Types (ADT). Usual Data Types Integer, Double, Boolean You do not know the implementation of these. There are some operations."— Presentation transcript:

1 Lecture 4 Abstract Data Types (ADT)

2 Usual Data Types Integer, Double, Boolean You do not know the implementation of these. There are some operations which can be done with these (add, multiply, read, write) Programmer just uses these operations without knowing their implementation.

3 Abstract Data Types Implement these data types once in the program Describe these operations once Use these operations again and again without going into the implementation However, the complexity of these operation depend on the implementation and should not be considered constant An ADT may use a different ADT

4 List Sequence of elements Operations Add an element at the beginning/end/ith position Delete an element at the beginning/end/ith position Access(read/change) an element at the beginning/end/ith position.

5 Array Implementation List can be implemented as an array Need to know the maximum number of elements in the list at the start of the program Adding/Deleting an element can take O(n) operations if the list has n elements. Accessing/changing an element anywhere takes O(1) operations independent of n

6 Adding an element Adding at the beginning: Move all elements one position behind Add at position 1; Increment the current size by 1 For (j = A[0]+1; j > 0; j--) A[j] = A[j-1]; A[1] = new element; A[0]  A[0]+1; Normally first position (A[0])stores the current size of the list Actual number of elements currsize + 1 Complexity: O(n)

7 Adding at the End Add the element at the end Increment current size by 1; A[A[0]+1] = new element; A[0]  A[0]+1; Complexity: O(1)

8 Adding at kth position Move all elements one position behind, kth position onwards; Add the element at the kth position Increment current size by 1; For (j = A[0]+1; j > k; j--) A[j] = A[j-1]; A[k] = new element; A[0]  A[0]+1; Complexity: O(n-k)

9 Deleting an Element Deleting at the beginning: Move all elements one position ahead; Decrement the current size by 1 For (j = 1; j < A[0] ; j++) A[j] = A[j+1]; A[0]  A[0]-1; Complexity: O(n)

10 Deleting at the End Delete the element at the end Decrement current size by 1; A[0]  A[0]-1; Complexity: O(1)

11 Deleting at the kth position Move all elements one position ahead, k+1th position onwards; Decrement the current size by 1; For (j = k; j < A[0]+1; j++) A[j] = A[j+1]; A[0]  A[0]-1; Complexity: O(n-k)

12 Accessing an Element at the kth position A[k]; O(1) operation;

13 Linked List A node in the linked list consists of two elements Value of the corresponding element in the list Pointer to the next element The pointer is a null pointer for the last element. Consists of a sequence of nodes May be a special node at the beginning, known as the header node

14 3 52 10NULL Header Size of the list

15 Adding an element at the beginning Create a new node; Element in the node has the same value as the new element; Node pointer points to the first element (non-header) Pointer from the header points to new node; Create(newnode); newnode.next  header.next.next header.next  newnode; O(1);

16 Adding an element at the end Create a new node; Element in the node has the same value as the new element; Node pointer points to the last element; Pointer from the last element points to new node; Create(newnode); newnode.next  last last.next  newnode;

17 Accessing an element; Move from the beginning till you find the element; For (findnode = start; findnode != NULL; findnode=findnode.next) Stop when you find the desired element; Complexity: O(n) May store a pointer for the special positions, e.g., last, but then update it as necessary;

18 Adding at the kth position Create new node; Access (k-1)th element; Pointer from new node points to kth element; Pointer from (k-1)th element points to kth element; Create(newnode); Acess (k-1)th node; newnode.next  (k-1)node.next; (k-1)node.next  newnode; Complexity: O(k)

19 Delete at the kth position Access the k-1th node; Deletenode = (k-1)thnode.next; (k-1)thnode.next = Deletenode.next; Delete (Deletenode); Complexity depends on access complexity; O(1) for deleting first element; O(1) or O(n) for deleting the last element; O(k) for any other element;

20 Advantage of Linked List Need not know the maximum number of elements ahead of time.

21 Doubly Linked List A node contains pointers to previous and next element; One can move in both directions;

22 3 52 10NULL Header Size of the list

23 Circular List The last node points to the first one; Useful in modulo operations; Suppose you want to move k mod N positions in the list, where N is the size of the list, then you may want to fold back;

24 Examples Class enrollment vs student record

25 Representation of Polynomials iaixiiaixi Have an entry in a linked list for each term. An entry contains the degree of the corresponding term and the value of the coefficient. Two polynomials can be added by adding corresponding terms in the linked list.

26 Stacks Stack is a list where you can access add or delete elements at one end. All of these operations take constant time. Stacks are called ``last in first out’’ (LIFO), the last added element among the current ones can be accessed or deleted. Deletion is ``pop’’ Addition is ``push’’ You can also find out whether the stack is empty but nothing else.

27 EXAMPLE Push 5, 3, 1, Pop, Pop, Push 7 Push 5 Push 3Push 1 Pop Push 7 5 5 3 3 5 1 5 3 Get 1 5 5 7 Get 3

28 Function Calls When a subroutine calls another subroutine (including itself) it must first store its register contents. So, it pushes the register contents into a stack. The new function uses the registers. When the program returns to the old function, pop the stack. Nested Function and Stack Overflow

29 Tower of Hanoi(k, source, auxilliary, destination) { If k=1 move peg from source to destination; Else, { Tower of Hanoi(top k-1, source, destination, auxilliary); Move kth peg from source to destination; Tower of Hanoi(k-1, auxilliary, source, destination); } return; } Push into stack Pop from stack

30 Stack Implementation Array Need to know the maximum number of elements Delete/Access/Add at the end O(1) operation. Store array length in the 0 th position. Delete/Access/Add at A[array length+1]

31 Example Push 5, 3, 1, Pop, Pop, Push 7 5 53 531 53 5 57

32 Linked List Implementation. Need not know the maximum size Need not have a special header. Add/Access/Delete in the beginning, O(1) Need several memory access, deletions.

33 Push 5, 3, 1, Pop, Pop, Push 7 5 NULL 53 53 1

34 53 5 57

35 Symbol Matching Braces, paranthenses, brackets, begin, ends must match each other [ { [ ( )] } ] [{]}() Easy check using stacks

36 Start from beginning of the file. Push the beginning symbols you wish to match, ignore the rest. Push brace, parantheses, brackets, ignore the alphabets Whenever you encounter a right symbol, pop an element from the stack. If stack is empty, then error. Otherwise, if the popped element is the corresponding left symbol, then fine, else there is an error. What is the complexity of the operation? O(n)

37 EXAMPLE Push [, Push {, Pop, Pop, Push (, Pop Push [ Push { Pop Expect? [ [ { [ Get { Check brace, bracket parentheses matching [a+b{1*2]9*1}+(2-1) Oops! Something wrong, was expecting [

38 EXAMPLE Push [, Push {, Pop, Pop, Push (, Pop Push [ Push {Pop Expect { Pop Expect [ Push (Pop Expect ( [ [ { [ Get [ ( Check brace, bracket parentheses matching [a+b{1*2}9*1]+(2-1) Get { Get ( Perfect!

39 Symbol Priority A*B + C A*(B + C) A+B+C*D A*D+B+C*E To do the correct operation, calculator needs to know the priority of operands We don’t need any priority nor parantheses if the operation is expressed in postfix or reverse polish notion.

40 Postfix A*B + C = AB*C+ A*D+B+C*E= AD*B+CE*+ = (B + C)*A= BC+A*A*(B + C) A+B+C*D= AB+CD*+ Suppose the expression is in postfix, how do we compute the value?

41 Computatation of a Postfix Expression Whenever you see a number push it in the stack. Whenever you see an operator, pop 2 numbers, apply the operator, Push the result At end Pop to get answer Complexity? O(n)

42 EXAMPLE Push 5 Push 4Pop Push 20 Push 6 55 4 5 Get 5 20 Compute 5*4+6+7*2 Result: 40 Postfix: 5 4*6+7 2*+ Get 4 20 6

43 Pop 20 Get 6Get 20 Push 26 26 Push 7 26 7 Push 2 26 7 2 Pop 26 7 Get 2 Pop 26 Get 7 Push 14 26 14 Pop 26 Get 14 Pop

44 Get 26 Push 40 40 Pop to get answer Section 3.3 in Weiss

45 Queues Section 3.4 in Weiss List where an element is inserted at the end, and deleted from the beginning Insertion deletion at different ends. First in First out Deletion and Insertion must be O(1)

46 Linked List Implementation Insert at the end of the linked list Maintain a pointer to the last element Whenever there is insertion, update this ``last’’ pointer to point to the newly inserted element. Delete from the beginning of the list Both insertion and deletion O(1)

47 Insert 5, 3, 1, Delete, Delete, Insert 7 5 NULL 35 13 5

48 13 1 71

49 Array Implementation Insertion at the end has complexity O(1) But deletion at beginning has complexity O(n) Solution: Use a circular array implementation

50 Implementing Queues using circular arrays Maintain length of the queue as a separate variable, not as the first element (for convenience). Start inserting from the beginning of the array. Insert at the end of the current list When an element is deleted from the beginning, DO NOT move all elements forward Just mark the position as blank. Any problem?

51 We will soon reach the end of the array even though there are spaces in the beginning. We roll back to the beginning. When the last element is at the end of the array, we insert a new element at the beginning Example: Note Down from the Board

52 EXAMPLE Insert 5, 3, 1, Delete, Delete, Insert 7 55 3 5 3 1 3 1 1 7 1

53 Implementation Routine Maintain two positions: Front, Rear Maintain Queue Size Initially, Front = 0, Rear = 0, Queue Size = 0

54 Deletion: If Queue Size = 0, conclude empty queue, and no deletion Else { Decrement Queue Size; Retrieve A[Front]; Change Front to (Front + 1) Modulo Array Size; }

55 If Queue Size = Array Size, conclude Full queue, and no insertion Else { Increment Queue Size; A[Rear] = new element; Change Rear to (Rear + 1) Modulo Array Size; } Insertion


Download ppt "Lecture 4 Abstract Data Types (ADT). Usual Data Types Integer, Double, Boolean You do not know the implementation of these. There are some operations."

Similar presentations


Ads by Google