Presentation is loading. Please wait.

Presentation is loading. Please wait.

© University of Auckland Trees CS 220 Data Structures & Algorithms Dr. Ian Watson.

Similar presentations


Presentation on theme: "© University of Auckland Trees CS 220 Data Structures & Algorithms Dr. Ian Watson."— Presentation transcript:

1 © University of Auckland www.cs.auckland.ac.nz/~ian/ ian@cs.auckland.ac.nz Trees CS 220 Data Structures & Algorithms Dr. Ian Watson

2 2 © University of Auckland www.cs.auckland.ac.nz/~ian/ ian@cs.auckland.ac.nz Non computer science view of a tree leaves branches root

3 3 © University of Auckland www.cs.auckland.ac.nz/~ian/ ian@cs.auckland.ac.nz The computer science view root branches leaves

4 4 © University of Auckland www.cs.auckland.ac.nz/~ian/ ian@cs.auckland.ac.nz Linear Lists And Trees Linear lists are useful for serially ordered data. (e 0, e 1, e 2, …, e n-1 ) Days of week. Months in a year. Students in this class. Trees are useful for hierarchically ordered data. Employees of a corporation. President, vice presidents, managers, and so on. Java’s classes. Object is at the top of the hierarchy. Subclasses of Object are next, and so on.

5 5 © University of Auckland www.cs.auckland.ac.nz/~ian/ ian@cs.auckland.ac.nz Hierarchical Data & Trees The element at the top of the hierarchy is the root Elements next in the hierarchy are the children of the root Elements next in the hierarchy are the grandchildren of the root, and so on… Elements at the lowest level of the hierarchy are the leaves

6 6 © University of Auckland www.cs.auckland.ac.nz/~ian/ ian@cs.auckland.ac.nz descendant of root grand children of root children of root Java’s Classes Object NumberThrowable OutputStream IntegerDoubleException FileOutputStream RuntimeException root

7 7 © University of Auckland www.cs.auckland.ac.nz/~ian/ ian@cs.auckland.ac.nz Definition A tree t is a finite nonempty set of elements One of these elements is called the root The remaining elements, if any, are partitioned into trees, which are called the subtrees of t

8 8 © University of Auckland www.cs.auckland.ac.nz/~ian/ ian@cs.auckland.ac.nz Subtrees Object NumberThrowable OutputStream IntegerDoubleException FileOutputStream RuntimeException root

9 9 © University of Auckland www.cs.auckland.ac.nz/~ian/ ian@cs.auckland.ac.nz Leaves Object NumberThrowable OutputStream IntegerDoubleException FileOutputStream RuntimeException

10 10 © University of Auckland www.cs.auckland.ac.nz/~ian/ ian@cs.auckland.ac.nz Parent, Grandparent, Siblings, Ancestors, Descendents Object NumberThrowable OutputStream IntegerDoubleException FileOutputStream RuntimeException

11 11 © University of Auckland www.cs.auckland.ac.nz/~ian/ ian@cs.auckland.ac.nz Levels Level 4 Level 3 Level 2 Object NumberThrowable OutputStream IntegerDoubleException FileOutputStream RuntimeException Level 1

12 12 © University of Auckland www.cs.auckland.ac.nz/~ian/ ian@cs.auckland.ac.nz Caution Some CS texts start level numbers at 0 rather than at 1 Root is at level 0 Its children are at level 1 The grand children of the root are at level 2 And so on

13 13 © University of Auckland www.cs.auckland.ac.nz/~ian/ ian@cs.auckland.ac.nz height = depth = number of levels Level 4 Level 3 Level 2 Object NumberThrowable OutputStream IntegerDoubleException FileOutputStream RuntimeException Level 1

14 14 © University of Auckland www.cs.auckland.ac.nz/~ian/ ian@cs.auckland.ac.nz Node Degree = Number Of Children Object NumberThrowable OutputStream IntegerDoubleException FileOutputStream RuntimeException 3 211 0010 0

15 15 © University of Auckland www.cs.auckland.ac.nz/~ian/ ian@cs.auckland.ac.nz Tree Degree = Max Node Degree Object NumberThrowable OutputStream IntegerDoubleException FileOutputStream RuntimeException 3 211 0010 0 Degree of tree = 3

16 16 © University of Auckland www.cs.auckland.ac.nz/~ian/ ian@cs.auckland.ac.nz Binary Tree Finite (possibly empty) collection of elements A nonempty binary tree has a root element The remaining elements (if any) are partitioned into two binary trees These are called the left and right subtrees of the binary tree

17 17 © University of Auckland www.cs.auckland.ac.nz/~ian/ ian@cs.auckland.ac.nz Differences Between a Tree & a Binary Tree No node in a binary tree may have a degree more than 2 There is no limit on the degree of a node in a tree A binary tree may be empty; a tree cannot be empty The subtrees of a binary tree are ordered Those of a tree are not ordered

18 18 © University of Auckland www.cs.auckland.ac.nz/~ian/ ian@cs.auckland.ac.nz The subtrees of a binary tree are ordered; those of a tree are not ordered. a b a b Trees 1 & 2 are different when viewed as binary trees (because of left right ordering). But they are the same when viewed as trees 12 Differences Between a Tree & a Binary Tree

19 19 © University of Auckland www.cs.auckland.ac.nz/~ian/ ian@cs.auckland.ac.nz Arithmetic Expressions (a + b) * (c + d) + e – f/g*h + 3.25 Expressions comprise three kinds of entities. Operators (+, -, /, *). Operands (a, b, c, d, e, f, g, h, 3.25, (a + b), (c + d), etc.). Delimiters ((, )).

20 20 © University of Auckland www.cs.auckland.ac.nz/~ian/ ian@cs.auckland.ac.nz Operator Degree Number of operands that the operator requires. Binary operator requires two operands.  a + b  c / d  e - f Unary operator requires one operand.  + g  - h

21 21 © University of Auckland www.cs.auckland.ac.nz/~ian/ ian@cs.auckland.ac.nz Infix Form Normal way to write an expression. Binary operators come in between their left and right operands.  a * b  a + b * c  a * b / c  (a + b) * (c + d) + e – f/g*h + 3.25

22 22 © University of Auckland www.cs.auckland.ac.nz/~ian/ ian@cs.auckland.ac.nz Operator Priorities How do you figure out the operands of an operator?  a + b * c  a * b + c / d This is done by assigning operator priorities.  priority(*) = priority(/) > priority(+) = priority(-) When an operand lies between two operators, the operand associates with the operator that has higher priority.

23 23 © University of Auckland www.cs.auckland.ac.nz/~ian/ ian@cs.auckland.ac.nz Tie Breaker When an operand lies between two operators that have the same priority, the operand associates with the operator on the left.  a + b - c  a * b / c / d

24 24 © University of Auckland www.cs.auckland.ac.nz/~ian/ ian@cs.auckland.ac.nz Delimiters Sub-expression within delimiters is treated as a single operand, independent from the remainder of the expression.  (a + b) * (c – d) / (e – f) single operand

25 25 © University of Auckland www.cs.auckland.ac.nz/~ian/ ian@cs.auckland.ac.nz Infix Expression Is Hard To Parse Need operator priorities, apply tie breaker, and find delimiters. This makes computer evaluation more difficult than is necessary. Postfix and prefix expression forms do not rely on operator priorities, a tie breaker, or delimiters (eg Polish notation) So it is easier for a computer to evaluate expressions that are in these forms.

26 26 © University of Auckland www.cs.auckland.ac.nz/~ian/ ian@cs.auckland.ac.nz Postfix Form The postfix form of a variable or constant is the same as its infix form.  a, b, 3.25 The relative order of operands is the same in infix and postfix forms. Operators come immediately after the postfix form of their operands.  Infix = a + b  Postfix = ab+

27 27 © University of Auckland www.cs.auckland.ac.nz/~ian/ ian@cs.auckland.ac.nz Postfix Examples Infix = a * b + c  Postfix = ab*c+ Infix = (a + b) * (c – d) / (e + f)  Postfix = ab+cd-*ef+/ postfix

28 28 © University of Auckland www.cs.auckland.ac.nz/~ian/ ian@cs.auckland.ac.nz Postfix Evaluation Scan postfix expression from left to right pushing operands on to a stack. When an operator is encountered, pop as many operands as this operator needs; evaluate the operator & push the result back on to the stack. This works because, in postfix, operators come immediately after their operands.

29 29 © University of Auckland www.cs.auckland.ac.nz/~ian/ ian@cs.auckland.ac.nz Postfix Evaluation (a + b) * (c – d) / (e + f) a b + c d - * e f + / stack a  a b + c d - * e f + / b

30 30 © University of Auckland www.cs.auckland.ac.nz/~ian/ ian@cs.auckland.ac.nz Postfix Evaluation (a + b) * (c – d) / (e + f) a b + c d - * e f + / stack (a + b)  a b + c d - * e f + / c d

31 31 © University of Auckland www.cs.auckland.ac.nz/~ian/ ian@cs.auckland.ac.nz Postfix Evaluation (a + b) * (c – d) / (e + f) a b + c d - * e f + / stack (a + b)  a b + c d - * e f + / (c – d)

32 32 © University of Auckland www.cs.auckland.ac.nz/~ian/ ian@cs.auckland.ac.nz Postfix Evaluation (a + b) * (c – d) / (e + f) a b + c d - * e f + / stack (a + b)*(c – d)  a b + c d - * e f + / e f

33 33 © University of Auckland www.cs.auckland.ac.nz/~ian/ ian@cs.auckland.ac.nz Postfix Evaluation (a + b) * (c – d) / (e + f) a b + c d - * e f + / stack (a + b)*(c – d)  a b + c d - * e f + / (e + f)  a b + c d - * e f + /


Download ppt "© University of Auckland Trees CS 220 Data Structures & Algorithms Dr. Ian Watson."

Similar presentations


Ads by Google