1 / 47

BCT 2083 DISCRETE STRUCTURE AND APPLICATIONS

BCT 2083 DISCRETE STRUCTURE AND APPLICATIONS. CHAPTER 4 TREES. SITI ZANARIAH SATARI FIST/FSKKP UMP I0910. CONTENT. 4.1 Introduction to Trees 4.2 Application of Trees 4.3 Tree Traversal 4.4 Trees and Sorting (Data structure) 4.5 Spanning Trees 4.6 Minimum Spanning Trees.

ceana
Download Presentation

BCT 2083 DISCRETE STRUCTURE AND APPLICATIONS

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. BCT 2083 DISCRETE STRUCTURE AND APPLICATIONS CHAPTER 4 TREES SITI ZANARIAH SATARI FIST/FSKKP UMP I0910

  2. CONTENT 4.1 Introduction to Trees 4.2 Application of Trees 4.3 Tree Traversal 4.4 Trees and Sorting (Data structure) 4.5 Spanning Trees 4.6 Minimum Spanning Trees CHAPTER 4 TREES

  3. CHAPTER 4 TREES • Define and recognize a tree • Define and recognize a rooted tree • Define and recognize a m-ary tree 4.1 INTRODUCTION TO TREES

  4. A Tree • A tree is a connected undirected graph with no simple circuit. • An undirected graph is a tree if and only if there is a unique simple path between any two of its vertices. • THEOREM: A tree with n vertices has n – 1 edges. 4.1 INTRODUCTION TO TREES EXAMPLES a b c a b c a b c d e f d e f d e f NOT A TREE A TREE NOT A TREE

  5. EXERCISE 4.1 • Which of the following graphs are trees? 4.1 INTRODUCTION TO TREES a b c a b c d e d e FIGURE 1 FIGURE 2 a v2 v1 v3 c d e v5 b v4 FIGURE 3 FIGURE 4

  6. A Rooted Tree • A rooted tree is a tree in which one vertex has been designated as the root and every edge is directed away from the root. • Different choice of root produce different rooted tree 4.1 INTRODUCTION TO TREES EXAMPLES c f g a a b d d c b e b d a g e e f g f c A TREE with root a A TREE with root c A TREE

  7. Properties of Rooted Trees • Parent – A vertex other than root is a parent if it has one or more children • The parent of c is b • Children – If A is a vertex with successors B and C, then B and C are the children of A. • The children of a is b, f and g • Siblings – Children with the same parent vertex. • h, i and j are siblings • Level – the length of the unique path from the root to a vertex • Vertex a is at level 0 • Vertices d and e is at level 3 4.1 INTRODUCTION TO TREES EXAMPLES a b g f j c h i e d k l m • Height – The maximum level of all the vertices • The height of this tree is 3.

  8. Properties of Rooted Trees • Ancestor of a vertex (v) – the vertices in the path from the root to this vertex excluding this vertex. • The ancestors of e are c, b and a • Descendent of a vertex (v) – vertices that have v as ancestor. • The descendants of b are c, d and e • Leaf – A vertex with no children • The leaves are d, e, f, i, k, l and m • Internal Vertices – vertices that have children • The internal vertices are a, b, c, g, h and j 4.1 INTRODUCTION TO TREES EXAMPLES a b g f j c h i e d k l m A subtree rooted at g • Subtree – A subgraph of the tree consisting of a root and its descendent and all edges incident to these descendent.

  9. EXERCISE 4.1 • Answer these questions about the rooted tree illustrated. 4.1 INTRODUCTION TO TREES • Which vertex is the root? • Which vertices are internal? • Which vertices are leaves? • Which vertices are children of g? • Which vertex is the parent of o? • Which vertices are siblings of e? • Which vertices are ancestors of m? • Which vertices are descendants of d? a b d • Find a subgraph. • Find the level of each vertex. • What is the height of this tree? • Is this tree a balanced tree? c e g f h i o j k l m n p r q s

  10. m-ary Tree • A rooted tree is called an m-ary tree if every vertex has no more than m children. • The tree is called a full m-ary tree if every internal vertex has exactly m children. • A rooted m-ary tree is balanced if all leaves are at levels h or h-1. 4.1 INTRODUCTION TO TREES EXAMPLES c a a a e b c d e b d c b d f g k j h i l m g e f g f A full binary TREE A 3-ary TREE A full 4-ary TREE

  11. m-ary Tree • THEOREM 1: A full m-ary tree with i internal vertices contains n = mi + 1 vertices • THEOREM 2: A full m-ary tree with • n vertices has internal vertices and leaves. • i internal vertices has vertices and leaves. • l leaves has vertices and internal vertices. • THEOREM 3: There are at most leaves in an m-ary tree of height h. 4.1 INTRODUCTION TO TREES

  12. EXAMPLE: m-ary tree Suppose that someone starts a chain letter. Each person who receives the letter is asked to send it on to four other people. Some people do this, but others do not send any letters. How many people have seen the letter, including the first person, if no one receives more than one letter and if the chain letter ends after there have been 100 people, who read it but did not send it out? 4.1 INTRODUCTION TO TREES Solution: Send letter to four other people ⇛ 4-ary tree ⇛ m = 4 People send out the letter ⇛ internal vertices ⇛ i People do not send out the letter ⇛ leaves ⇛ l = 100 By theorem 2 (iii): Number of people have seen this letter ⇛ n = (4·100 –1) / (4 – 1) = 133 Number of people send out the letter⇛ i = 133 – 100 = 33

  13. EXERCISE 4.1 • A chain letter starts with a person sending a letter out to 10 others. Each person is asked to send the letter out to 10 others, and each letter contains a list of previous six people in the chain. Unless there are fewer than six names in the list, each person sends one dollar to the first person from the list, moves up each of other five names one position, and insert his names at the end of this list. If no person breaks the chain and no one receives more than one letter, how much money will a person in the chain ultimately receive? 4.1 INTRODUCTION TO TREES

  14. EXERCISE 4.1 : EXTRA PAGE : 693, 694 and 695 Rosen K.H., Discrete Mathematics & Its Applications, (Seventh Edition), McGraw-Hill, 2007. 4.1 INTRODUCTION TO TREES

  15. 4.2 APPLICATION OF TREES CHAPTER 4 TREES • Introduce Binary Search Trees • Introduce Decision Trees • Introduce Game Trees

  16. Binary Search Trees • A binary tree in which each child of a vertex is designated as a right or left child • No vertex has more than one right child or left child • Each vertex is labeled with a key • Vertices are assigned keys so that the key of a vertex is both larger than the keys of all vertices in its left subtree and smaller than the keys of all vertices in its right subtree. 4.2 APPLICATION OF TREES EXAMPLE Binary search tree for the words mathematics, physics, geography, zoology, meteorology, geology, psychology, and chemistry using alphabetical order mathematics physics geography chemistry geology zoology metereology psycology

  17. Decision Trees • A rooted tree in which each internal vertex corresponds to a decision, with a subtree at these vertices for each possible outcome of decision. • The possible solutions of the problem correspond to the paths to the leaves of this rooted tree. 4.2 APPLICATION OF TREES EXAMPLE A Decision tree that orders the elements of the list a, b, c a : b a <b a >b a : c b : c a <c b <c a >c b >c b : c c > a > b a : c c > b > a b <c a <c b >c a >c a > b > c a > c > b b > a > c b > c > a

  18. Game Trees • Use trees to analyze certain types of games • Vertices represent the positions can be in as it progresses • Edges represent legal moves between this position • Games tree is infinite if the games they represent never end 4.2 APPLICATION OF TREES EXAMPLE A Game tree that represents the first two level of the tic-tac-toe game.

  19. EXERCISE 4.2 : EXTRA PAGE : 708, 709 and 710 Rosen K.H., Discrete Mathematics & Its Applications, (Seventh Edition), McGraw-Hill, 2007. 4.2 APPLICATION OF TREES

  20. 4.3 TREE TRAVERSAL CHAPTER 4 TREES • Determine preorder traversal, inorder traversal and postorder traversal of an ordered rooted tree. • Determine the infix, prefix, and postfix form of an expression.

  21. Tree Traversal • Ordered trees are often used to restore data/info. • Tree traversal is a procedure for systematically visiting each vertex of an ordered rooted tree to access data. • If the tree is label by Universal Address System we can totally order the vertices using lexicographic ordering • Example: 0 < 1 < 1.1 < 1.2 < 1.2.1 < 1.3 < 2 < 3 < 3.1 < 3.1.1 < 3.1.2 < 3.1.2.1 < 3.1.2.2 < 4 < 4.1 • Tree traversal algorithm • Preorder, inorder and postorder traversal 4.3 TREE TRAVERSAL

  22. Preorder Traversal • Let T be an ordered rooted tree with root r. • If T consists only of r, then r is the preorder traversal of T. • If T1, T2, …, Tn are subtrees at r from left to right in T, then the preorder traversal begins by visiting r, continues by traversing T1 in preorder, then T2 in preorder, and so on until Tn is traversed in preorder. 4.3 TREE TRAVERSAL STEP 1 Visit r r TIPS Preorder Traversal: Visit root, visit subtrees left to right … T1 T2 Tn STEP 2 Visit T1 in preorder STEP 3 Visit T2 in preorder STEP n+1 Visit Tn in preorder

  23. EXAMPLE: Preorder Traversal 4.3 TREE TRAVERSAL a a• b• e f• c• d• g h• i• T d b c e k f m g h l j i k j m l n ITERATION 2 p o n p o a• b• e• j• f• c• d• g• l• m• h• i• k d a• b c• n ITERATION 3 p o e f g h i a• b• e• j• k• n• o• p• f• c• d• g• l• m• h• i• k j m l ITERATION 4 n p o ITERATION 1 The preorder traversal of T

  24. Inorder Traversal • Let T be an ordered rooted tree with root r. • If T consists only of r, then r is the inorder traversal of T. • If T1, T2, …, Tn are subtrees at r from left to right in T, then the inorder traversal begins by traversing T1 in inorder, then visiting r, continues by traversing T2 in inorder, and so on until Tn is traversed in inorder. 4.3 TREE TRAVERSAL STEP 2 Visit r r TIPS Inorder Traversal: Visit leftmost subtree, Visit root, Visit other subtrees left to right. … T1 T2 Tn STEP 1 Visit T1 in inorder STEP 3 Visit T2 in inorder STEP n+1 Visit Tn in inorder

  25. EXAMPLE: Inorder Traversal 4.3 TREE TRAVERSAL a e b• f• a• c• g d• h• i• T d b c e k f m g h l j i k j m l n ITERATION 2 p o n p o j• e• b• f• a• c• l• g• m• d• h• i• k d b a• c• n ITERATION 3 p o e f g h i j• e• n• k• o• p• b• f• a• c• g• m• d• h• i• l• k j m l ITERATION 4 n p o ITERATION 1 The inorder traversal of T

  26. Postorder Traversal • Let T be an ordered rooted tree with root r. • If T consists only of r, then r is the postorder traversal of T. • If T1, T2, …, Tn are subtrees at r from left to right in T, then the preorder traversal begins by traversing T1 in postorder, then T2 in postorder, and so on until Tn is traversed in postorder and ends by visiting r. 4.3 TREE TRAVERSAL STEP n+1 Visit r r TIPS Postorder Traversal: Visit subtrees left to right, Visit root. … T1 T2 Tn STEP 1 Visit T1 in postorder STEP 2 Visit T2 in postorder STEP n Visit Tn in postorder

  27. EXAMPLE: Postorder Traversal 4.3 TREE TRAVERSAL a e f• b• c• g h• i• d• a• T d b c e k f m g h l j i k j m l n ITERATION 2 o p n p o f• b• c• d• a• j• e• l• m• g• h• i• k d b c• a• n ITERATION 3 o p e f g h i j• n• o• p• k• e• f• b• c• l• m• g• h• i• d• a• k j m l ITERATION 4 n p o ITERATION 1 The preorder traversal of T

  28. EXERCISE 4.3 • Determine the order in which a preorder, inorder, and postorder traversal visits the vertices of the following rooted tree. 4.3 TREE TRAVERSAL a a b b d g f c e g f j c h h i i j o k l e m d k l p m n r q s FIGURE 1 FIGURE 2

  29. Represent Expression by Rooted Tree • We can represent complicated expression (propositions, sets, arithmetic) using ordered rooted trees. • EXAMPLE: A binary tree representing ((x+y)↑2)+((x-4)/3) 4.3 TREE TRAVERSAL + ↑ / _ + 2 3 x y x 4

  30. Infix, Prefix & Postfix Notation • We obtain the Infix form of an expression when we traverse its rooted tree in Inorder. • The infix form for expression ((x+y)↑2)+((x-4)/3) is x + y ↑2 + x – 4 / 3 or ((x+y)↑2)+((x-4)/3) • We obtain the Prefix form of an expression when we traverse its rooted tree in Preorder. • The prefix form for expression ((x+y)↑2)+((x-4)/3) is + ↑ + xy 2 / - x 4 3 • We obtain the Postfix form of an expression when we traverse its rooted tree in Postorder. • The postfix form for expression ((x+y)↑2)+((x-4)/3) is x y + 2 ↑ x 4 – 3 / + 4.3 TREE TRAVERSAL

  31. Evaluating Prefix Expression • Working right to left and performing operations using the operands on the right. • EXAMPLE: The value of the prefix expression + - * 2 3 5 / ↑ 2 3 4 is 3 4.3 TREE TRAVERSAL + - * 2 3 5 / ↑ 2 3 4 + - * 2 3 5 2 2 ↑ 3 = 8 2 * 3 = 6 + - 6 5 2 + - * 2 3 5 / 8 4 8/4 =2 6 – 5 =1 + - * 2 3 5 2 + 1 2 2 * 3 = 6 1 + 2 = 3

  32. Evaluating Postfix Expression • Working left to right and performing operations using the operands on the left. • EXAMPLE: The value of the postfix expression 7 2 3 * - 4 ↑ 9 3 / + is 4 4.3 TREE TRAVERSAL 7 2 3 * - 4 ↑ 9 3 / + 1 4 ↑ 9 3 / + 1 ↑ 4 = 1 2 * 3 = 6 7 6 - 4 ↑ 9 3 / + 1 9 3 / + 7 - 6 = 1 9/3 = 3 1 4 ↑ 9 3 / + 1 3 + 1 ↑ 4 = 1 1 + 3 = 4

  33. EXERCISE 4.3 • Represent the following expression using binary trees. Then write these expression in infix, prefix and postfix notations. • ((x+2)↑3)*(y – (3+x)) – 5 • (A∩B) – (A∪(B – A)) • What is the value of these expression in prefix expression? • + – ↑3 2 ↑ 2 3 / 6 – 4 2 • * + 3 + 3 ↑ 3 + 3 3 3 • What is the value of these expression in postfix expression? • 3 2 * 2 ↑ 5 3 – 8 4 / * – • 9 3 / 5 + 7 2 – * 4.3 TREE TRAVERSAL

  34. EXERCISE 4.3 : EXTRA PAGE : 722, 723 and 724 Rosen K.H., Discrete Mathematics & Its Applications, (Seventh Edition), McGraw-Hill, 2007. 4.3 TREE TRAVERSAL

  35. 4.5 SPANNING TREES CHAPTER 4 TREES • Find spanning trees of a simple graph

  36. Spanning Trees • Let G be a simple graph. A spanning tree of G is a subgraph of G that is a tree containing every vertex of G. • A simple graph is connected if and only if it has a spanning tree. • Applied in IP multitasking. 4.5 SPANNING TREES a b c d a b c d Not Spanning tree e f g a b c d e f g Spanning tree A simple graph e f g

  37. EXERCISE 4.5 • Find a spanning tree for the following graphs. 4.5 SPANNING TREES b a b f e c a g h d e d c FIGURE 1 FIGURE 2 b b a a e c c d d FIGURE 3 FIGURE 4

  38. EXERCISE 4.5 : EXTRA PAGE : 734, 735, 736 and 737 Rosen K.H., Discrete Mathematics & Its Applications, (Seventh Edition), McGraw-Hill, 2007. 4.5 SPANNING TREES

  39. 4.6 MINIMUM SPANNING TREES CHAPTER 4 TREES • Find minimum spanning tree using Prim’s algorithm • Find minimum spanning tree using Kruskal’s algorithm

  40. Minimum Spanning Trees • A minimum spanning tree in a connected weighted graph is a spanning tree that has the smallest possible sum of weights of it edges. • Two algorithms can be used: • Prim’s Algorithm • Robert Prim, 1957 • Kruskal’s Algorithm • Joseph Kruskal, 1956 4.6 MINIMUM SPANNING TREES

  41. Prim’s Algorithm • Chose an edge with the least weight. • Include it in spanning tree, T. • Select an edge of least weight that is incident with a vertex of an edge in T. • If it does not create a cycle (simple circuit) with the edges in T, then include it in T; otherwise discard it. • Repeat STEPS 3 and 4 until T contains n-1 edges. • There may be more than one minimum spanning tree for a given connected weighted simple graph. • If there are two edges with similar smallest weight, chose either one. 4.6 MINIMUM SPANNING TREES

  42. EXAMPLE: Prim’s Algorithm 4.6 MINIMUM SPANNING TREES c 13 13 b 10 b d 16 7 15 12 7 a 11 10 a b d e 12 7 10 FIGURE 1 a The minimum spanning tree is given by: b d 7 10 c 11 a e d 12 b c d 12 b 7 10 11 e a 7 10 11 e a Total weight = 40

  43. Kruskal’s Algorithm • Arrange the edges in G in increasing order. • Chose an edge with the minimum weight. • Include it in spanning tree, T. • Add an edge of least weight to T. • If it does not create a cycle (simple circuit) with the edges in T, then include it in T; otherwise discard it. • Repeat STEPS 4 and 5 until T contains n-1 edges. • There may be more than one minimum spanning tree for a given connected weighted simple graph. • If there are two edges with similar smallest weight, chose either one. 4.6 MINIMUM SPANNING TREES

  44. EXAMPLE: Kruskal’s Algorithm 4.6 MINIMUM SPANNING TREES c 13 13 b 10 b d 16 7 15 12 7 a 11 10 a b d e 12 10 7 FIGURE 1 a The minimum spanning tree is given by: b d 10 7 c 11 a e b d c 10 12 b d 7 10 11 e 12 a 7 11 e a Total weight = 40

  45. EXERCISE 4.6 • Construct a minimum spanning tree for each of the following connected weighted graphs using Prim’s and Kruskal’s algorithm. 4.6 MINIMUM SPANNING TREES a b 8 c f 3 11 1 6 1 2 e 1 2 8 5 3 7 6 b e a f 8 1 2 1 1 h g 3 5 d c 7 d FIGURE 1 FIGURE 2

  46. EXERCISE 4.6 : EXTRA PAGE : 742 and 743 Rosen K.H., Discrete Mathematics & Its Applications, (Seventh Edition), McGraw-Hill, 2007. 4.6 MINIMUM SPANNING TREES

  47. CHAPTER 4 TREES • Tree is a connected undirected graph with no simple circuits • Trees have been employed to solve problems in a wide variety of disciplines. SUMMARY

More Related