ATLAS Offline Software
|
Balanced binary tree. More...
Go to the source code of this file.
Macros | |
#define | AVL_TREE_NULL ((void *) 0) |
A null AVLTreeValue. More... | |
Typedefs | |
typedef struct _AVLTree | AVLTree |
An AVL tree balanced binary tree. More... | |
typedef void * | AVLTreeKey |
A key for an AVLTree. More... | |
typedef void * | AVLTreeValue |
A value stored in an AVLTree. More... | |
typedef struct _AVLTreeNode | AVLTreeNode |
A node in an AVL tree. More... | |
typedef int(* | AVLTreeCompareFunc) (AVLTreeValue value1, AVLTreeValue value2) |
Type of function used to compare keys in an AVL tree. More... | |
Enumerations | |
enum | AVLTreeNodeSide { AVL_TREE_NODE_LEFT = 0, AVL_TREE_NODE_RIGHT = 1 } |
An AVLTreeNode can have left and right children. More... | |
Functions | |
AVLTree * | avl_tree_new (AVLTreeCompareFunc compare_func) |
Create a new AVL tree. More... | |
void | avl_tree_free (AVLTree *tree) |
Destroy an AVL tree. More... | |
AVLTreeNode * | avl_tree_insert (AVLTree *tree, AVLTreeKey key, AVLTreeValue value) |
Insert a new key-value pair into an AVL tree. More... | |
void | avl_tree_remove_node (AVLTree *tree, AVLTreeNode *node) |
Remove a node from a tree. More... | |
int | avl_tree_remove (AVLTree *tree, AVLTreeKey key) |
Remove an entry from a tree, specifying the key of the node to remove. More... | |
AVLTreeNode * | avl_tree_lookup_node (AVLTree *tree, AVLTreeKey key) |
Search an AVL tree for a node with a particular key. More... | |
AVLTreeValue | avl_tree_lookup (AVLTree *tree, AVLTreeKey key) |
Search an AVL tree for a value corresponding to a particular key. More... | |
AVLTreeNode * | avl_tree_root_node (AVLTree *tree) |
Find the root node of a tree. More... | |
AVLTreeKey | avl_tree_node_key (AVLTreeNode *node) |
Retrieve the key for a given tree node. More... | |
AVLTreeValue | avl_tree_node_value (AVLTreeNode *node) |
Retrieve the value at a given tree node. More... | |
AVLTreeNode * | avl_tree_node_child (AVLTreeNode *node, AVLTreeNodeSide side) |
Find the child of a given tree node. More... | |
AVLTreeNode * | avl_tree_node_parent (AVLTreeNode *node) |
Find the parent node of a given tree node. More... | |
int | avl_tree_subtree_height (AVLTreeNode *node) |
Find the height of a subtree. More... | |
AVLTreeValue * | avl_tree_to_array (AVLTree *tree) |
Convert the keys in an AVL tree into a C array. More... | |
int | avl_tree_num_entries (AVLTree *tree) |
Retrieve the number of entries in the tree. More... | |
Balanced binary tree.
The AVL tree structure is a balanced binary tree which stores a collection of nodes (see AVLTreeNode). Each node has a key and a value associated with it. The nodes are sorted within the tree based on the order of their keys. Modifications to the tree are constructed such that the tree remains balanced at all times (there are always roughly equal numbers of nodes on either side of the tree).
Balanced binary trees have several uses. They can be used as a mapping (searching for a value based on its key), or as a set of keys which is always ordered.
To create a new AVL tree, use avl_tree_new. To destroy an AVL tree, use avl_tree_free.
To insert a new key-value pair into an AVL tree, use avl_tree_insert. To remove an entry from an AVL tree, use avl_tree_remove or avl_tree_remove_node.
To search an AVL tree, use avl_tree_lookup or avl_tree_lookup_node.
Tree nodes can be queried using the avl_tree_node_child, avl_tree_node_parent, avl_tree_node_key and avl_tree_node_value functions.
Definition in file avl-tree.h.
#define AVL_TREE_NULL ((void *) 0) |
A null AVLTreeValue.
Definition at line 86 of file avl-tree.h.
typedef struct _AVLTree AVLTree |
typedef int(* AVLTreeCompareFunc) (AVLTreeValue value1, AVLTreeValue value2) |
Type of function used to compare keys in an AVL tree.
value1 | The first key. |
value2 | The second key. |
Definition at line 119 of file avl-tree.h.
typedef void* AVLTreeKey |
Definition at line 73 of file avl-tree.h.
typedef struct _AVLTreeNode AVLTreeNode |
A node in an AVL tree.
Definition at line 79 of file avl-tree.h.
typedef void* AVLTreeValue |
Definition at line 79 of file avl-tree.h.
enum AVLTreeNodeSide |
An AVLTreeNode can have left and right children.
Enumerator | |
---|---|
AVL_TREE_NODE_LEFT | |
AVL_TREE_NODE_RIGHT |
Definition at line 103 of file avl-tree.h.
void avl_tree_free | ( | AVLTree * | tree | ) |
Destroy an AVL tree.
tree | The tree to destroy. |
AVLTreeNode* avl_tree_insert | ( | AVLTree * | tree, |
AVLTreeKey | key, | ||
AVLTreeValue | value | ||
) |
Insert a new key-value pair into an AVL tree.
tree | The tree. |
key | The key to insert. |
value | The value to insert. |
AVLTreeValue avl_tree_lookup | ( | AVLTree * | tree, |
AVLTreeKey | key | ||
) |
Search an AVL tree for a value corresponding to a particular key.
This uses the tree as a mapping. Note that this performs identically to avl_tree_lookup_node, except that the value at the node is returned rather than the node itself.
tree | The AVL tree to search. |
key | The key to search for. |
AVLTreeNode* avl_tree_lookup_node | ( | AVLTree * | tree, |
AVLTreeKey | key | ||
) |
Search an AVL tree for a node with a particular key.
This uses the tree as a mapping.
tree | The AVL tree to search. |
key | The key to search for. |
AVLTree* avl_tree_new | ( | AVLTreeCompareFunc | compare_func | ) |
Create a new AVL tree.
compare_func | Function to use when comparing keys in the tree. |
AVLTreeNode* avl_tree_node_child | ( | AVLTreeNode * | node, |
AVLTreeNodeSide | side | ||
) |
Find the child of a given tree node.
node | The tree node. |
side | Which child node to get (left or right) |
AVLTreeKey avl_tree_node_key | ( | AVLTreeNode * | node | ) |
Retrieve the key for a given tree node.
node | The tree node. |
AVLTreeNode* avl_tree_node_parent | ( | AVLTreeNode * | node | ) |
Find the parent node of a given tree node.
node | The tree node. |
AVLTreeValue avl_tree_node_value | ( | AVLTreeNode * | node | ) |
Retrieve the value at a given tree node.
node | The tree node. |
int avl_tree_num_entries | ( | AVLTree * | tree | ) |
Retrieve the number of entries in the tree.
tree | The tree. |
int avl_tree_remove | ( | AVLTree * | tree, |
AVLTreeKey | key | ||
) |
Remove an entry from a tree, specifying the key of the node to remove.
tree | The tree. |
key | The key of the node to remove. |
void avl_tree_remove_node | ( | AVLTree * | tree, |
AVLTreeNode * | node | ||
) |
Remove a node from a tree.
tree | The tree. |
node | The node to remove |
AVLTreeNode* avl_tree_root_node | ( | AVLTree * | tree | ) |
Find the root node of a tree.
tree | The tree. |
int avl_tree_subtree_height | ( | AVLTreeNode * | node | ) |
Find the height of a subtree.
node | The root node of the subtree. |
AVLTreeValue* avl_tree_to_array | ( | AVLTree * | tree | ) |
Convert the keys in an AVL tree into a C array.
This allows the tree to be used as an ordered set.
tree | The tree. |