SoftUni Team Technical Trainers Software University Trees and Tree-Like Structures Trees, Tree-Like Structures, Binary Search Trees, Balanced Trees, Implementations
2 1.Tree-like Data Structures 2.Trees and Related Terminology 3.Implementing Trees 4.Binary Trees and Traversals Pre-order (node, left, right) In-order (left, node, right) Post-order (left, right, node) 5.Balanced Search Trees 6.Graphs Table of Contents
Tree-like Data Structures Trees, Balanced Trees, Graphs, Networks
4 Tree-like data structures are: Branched recursive data structures Consisting of nodes Each node connected to other nodes Examples of tree-like structures Trees: binary, balanced, ordered, etc. Graphs: directed / undirected, weighted, etc. Networks: graphs with multiple relations between nodes Tree-like Data Structures
5 Project Manager Team Leader Designer QA Team Leader Developer 1 Developer 2 Tester 1 Developer 3 Tester 2 Tree Graph (20) 5 (10) 15 (15) 15 (30) 5 (5) 20(20) 10 (40) Network
Trees and Related Terminology Node, Edge, Root, Children, Parent, Leaf, Binary Search Tree, Balanced Tree Project Manager Team Leader Designer QA Team Leader
7 Node, edge, root, child, children, siblings, parent, ancestor, descendant, predecessor, successor, internal node, leaf, depth, height, subtree Tree Data Structure – Terminology Height = 3 Depth 0 Depth 1 Depth
Implementing Trees Recursive Tree Data Structure
The recursive definition for tree data structure: A single node is tree Tree nodes can have zero or multiple children that are also trees Tree node definition in C# public class Tree public class Tree { private T value; private T value; private IList > children; private IList > children; …} 9 Recursive Tree Definition The value stored in the node List of child nodes, which are of the same type
10 Tree Structure – Example 7children 19children21children14children Tree 1children 12children 31children23children6children int value IList > children
public class Tree public class Tree { public T Value { get; set; } public T Value { get; set; } public IList > Children { get; private set; } public IList > Children { get; private set; } public Tree(T value, params Tree [] children) public Tree(T value, params Tree [] children) { this.Value = value; this.Value = value; this.Children = new List >(); this.Children = new List >(); foreach (var child in children) foreach (var child in children) { this.Children.Add(child); this.Children.Add(child); } }} 11 Implementing Tree Flexible constructor for building trees
12 Constructing a tree by nested constructors: Building a Tree Tree tree = new Tree (7, new Tree (7, new Tree (19, new Tree (19, new Tree (1), new Tree (1), new Tree (12), new Tree (12), new Tree (31)), new Tree (31)), new Tree (21), new Tree (21), new Tree (14, new Tree (14, new Tree (23), new Tree (23), new Tree (6)) new Tree (6)));
13 Printing a tree at the console – recursive algorithm Printing a Tree public class Tree public class Tree { … public void Print(int indent = 0) public void Print(int indent = 0) { Console.Write(new string(' ', 2 * indent)); Console.Write(new string(' ', 2 * indent)); Console.WriteLine(this.Value); Console.WriteLine(this.Value); foreach (var child in this.Children) foreach (var child in this.Children) child.Print(indent + 1); child.Print(indent + 1); }}
Lab Exercise Trees and Trees Traversal
Binary Trees and Traversals Preorder, In-Order, Post-Order
16 Binary trees: the most widespread form Each node has at most 2 children (left and right) Binary Trees Root node Left subtree Right child Left child
Binary Trees Traversal Binary trees can be traversed in 3 ways: Pre-order: root, left, right In-order: left, root, child Post-order: left, right, root Example: Arithmetic expression stored as binary tree: (3 + 2) * (9 - 6) * Pre-order: * In-order: * Post-order: *
Lab Exercise Binary Trees and Traversal
19 Binary search trees are ordered For each node x in the tree All the elements in the left subtree of x are ≤ x All the elements in the right subtree of x are > x Binary search trees can be balanced Balanced trees have for each node Nearly equal number of nodes in its subtrees Balanced trees have height of ~ log(x) Binary Search Trees
20 Example of balanced binary search tree If the tree is balanced, add / search / delete operations take approximately log(n) steps Binary Search Trees (2)
Balanced Search Trees AVL Trees, B-Trees, Red-Black Trees, AA-Trees
22 Ordered Binary Trees (Binary Search Trees) For each node x the left subtree has values ≤ x and the right subtree has values > x Balanced Trees For each node its subtrees contain nearly equal number of nodes nearly the same height Balanced Binary Search Trees Ordered binary search trees that have height of log 2 (n) where n is the number of their nodes Searching costs about log 2 (n) comparisons Balanced Binary Search Trees
23 Balanced BST characteristics: 1. It has a maximum of two children per node (left and right) 2. It has a set of rules for determining when a branch is too deep or too wide after insertion or deletion 3. It has a procedure for rearranging the tree when the rules are violated (i.e. rebalancing) Balanced Binary Search Trees (2) NIL NIL NIL NILNIL NIL NIL NIL NIL NIL NIL
24 Balanced Binary Search Tree – Example The left subtree has 7 nodes The right subtree has 6 nodes
25 Balanced binary search trees are hard to implement Rebalancing the tree after insert / delete is complex Rotations change the structure without interfering the nodes' order Well-known implementations of balanced binary search trees: AVL Trees – ideally balanced, very complex Red-black Trees – roughly balanced, more simple AA-Trees – relatively simple to implement Find / insert / delete operations need log(n) steps Balanced Binary Search Trees
26 AVL tree is a self-balancing binary-search tree AVL tree See visualizationvisualization Named after Adelson-Velskii and Landis Height of two subtrees can differ by at most 1 Balance is preserved with a balance factor (BF) in each node BF of any node is in the range [-1, 1] If BF becomes -2 or 2 -> rebalance AVL Tree – Example
27 Red-Black tree – binary search tree with red and black nodes Red-Black tree Not perfectly balanced, but has height of O(log(n)) Used in C# and Java See the visualizationvisualization AVL vs. Red-Black AVL has faster search (it is better balanced) Red-Black has faster insert / delete Red-Black Tree – Example NIL NIL NIL NILNIL NIL NIL NIL NIL NIL NIL
28 AA tree (Arne Andersson) AA tree Simple self-balancing binary-search tree Simplified Red-Black tree Easier to implement than AVL and Red-Black Some Red-Black rotations are not needed AA Tree – Example
29 B-trees are generalization of the concept of ordered binary search trees – see the visualization B-treesvisualization B-tree of order b has between b and 2*b keys in a node and between b+1 and 2*b+1 child nodes The keys in each node are ordered increasingly All keys in a child node have values between their left and right parent keys If the B-tree is balanced, its search / insert / add operations take about log(n) steps B-trees can be efficiently stored on the disk B-Trees
30 B-Tree of order 4 (max number of child nodes) B-Tree – Example
Balanced Search Trees AVL Trees, B-Trees, Red-Black Trees, AA-Trees
32 .NET Framework has several built-in implementations of balanced search trees: SortedDictionary Red-black tree based dictionary (map) of key-value pairs SortedSet Red-black tree based set of elements External libraries like "Wintellect Power Collections for.NET" are more flexible Balanced Trees in.NET
33 In.NET Framework SortedSet is based on red-black tree Holds an ordered set of non-repeating elements Insert / delete / find / subset has O(log(n)) running time SortedSet : Red-Black Tree in.NET var set = new SortedSet (); set.Add(5); // 5 set.Add(8); // 5, 8 set.Add(-2); // -2, 5, 8 set.Add(30); // -2, 5, 8, 30 set.Add(20); // -2, 5, 8, 20, 30 var subset = set.GetViewBetween(5, 20); subset.ToList().ForEach(Console.WriteLine); // 5, 8, 20
Graphs Set of Nodes Connected with Edges
35 Graph (denoted as G(V, E) ) Set of nodes V with many-to-many relationship between them (edges E ) Each node (vertex) has multiple predecessors and multiple successors Edges connect two nodes (vertices) Graph Data Structure Node with multiple predecessors Node with multiple successors Self-relationship Node Edge
36 Node (vertex) Element of graph Can have name or value Keeps a list of adjacent nodes Edge Connection between two nodes Can be directed / undirected Can be weighted / unweighted Can have name / value Graph Definitions A Node A Edge B
37 Directed graph Edges have direction Graph Definitions (2) Undirected graph Edges have no direction G J F D A E C H
38 Weighted graph Weight (cost) is associated with each edge: Graph Definitions (3) G J F D A E C H Q K N
39 Typically graphs are stored as lists of descendant nodes Instead of nodes, usually their index (number) is stored Graphs – Implementation public class Graph { List [] childNodes; List [] childNodes; public Graph(List [] nodes) public Graph(List [] nodes) { this.childNodes = nodes; this.childNodes = nodes; }} Graph g = new Graph(new List [] { new List {3, 6}, // successors of vertex 0 new List {3, 6}, // successors of vertex 0 new List {2, 3, 4, 5, 6},// successors of vertex 1 new List {2, 3, 4, 5, 6},// successors of vertex 1 new List {1, 4, 5}, // successors of vertex 2 new List {1, 4, 5}, // successors of vertex 2 new List {0, 1, 5}, // successors of vertex 3 new List {0, 1, 5}, // successors of vertex 3 new List {1, 2, 6}, // successors of vertex 4 new List {1, 2, 6}, // successors of vertex 4 new List {1, 2, 3}, // successors of vertex 5 new List {1, 2, 3}, // successors of vertex 5 new List {0, 1, 4} // successors of vertex 6 new List {0, 1, 4} // successors of vertex 6});
40 Trees are recursive data structures A tree is a node holding a set of children (which are also nodes) Binary search trees are ordered binary trees Balanced trees have weight of log(n) AVL trees, Red-Black trees and AA trees are self-balancing binary search trees, used to implement ordered sets, bags and dictionaries Graph == set of nodes with many-to-many relationships Can be directed / undirected, weighted / unweighted, connected / not connected, etc. Summary
? ? ? ? ? ? ? ? ? Trees and Tree-Like Structures
License This course (slides, examples, labs, videos, homework, etc.) is licensed under the "Creative Commons Attribution- NonCommercial-ShareAlike 4.0 International" licenseCreative Commons Attribution- NonCommercial-ShareAlike 4.0 International 42 Attribution: this work may contain portions from "Fundamentals of Computer Programming with C#" book by Svetlin Nakov & Co. under CC-BY-SA licenseFundamentals of Computer Programming with C#CC-BY-SA "Data Structures and Algorithms" course by Telerik Academy under CC-BY-NC-SA licenseData Structures and AlgorithmsCC-BY-NC-SA
Free Software University Software University Foundation – softuni.orgsoftuni.org Software University – High-Quality Education, Profession and Job for Software Developers softuni.bg softuni.bg Software Facebook facebook.com/SoftwareUniversity facebook.com/SoftwareUniversity Software YouTube youtube.com/SoftwareUniversity youtube.com/SoftwareUniversity Software University Forums – forum.softuni.bgforum.softuni.bg