132 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			132 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /** <plaintext>
 | |
| *
 | |
| *  avl.h -- public types and external declarations for avl trees
 | |
| *
 | |
| *  Created 03/01/89 by Brad Appleton
 | |
| *
 | |
| * ^{Mods:* }
 | |
| *
 | |
| * Fri Jul 14 13:54:12 1989, Rev 1.0, brad(0165)
 | |
| *
 | |
| **/
 | |
| 
 | |
| #ifndef AVL_H_INCLUDED
 | |
| #define AVL_H_INCLUDED
 | |
| 
 | |
|        /* definition of traversal type */
 | |
| typedef  enum  { PREORDER, INORDER, POSTORDER }  VISIT;
 | |
| 
 | |
| 
 | |
|        /* definition of sibling order type */
 | |
| typedef  enum  { LEFT_TO_RIGHT, RIGHT_TO_LEFT }  SIBLING_ORDER;
 | |
| 
 | |
| 
 | |
|        /* definition of node type */
 | |
| typedef  enum  { IS_TREE, IS_LBRANCH, IS_RBRANCH, IS_LEAF, IS_NULL }  NODE;
 | |
| 
 | |
|   /* definition of a NULL action and a NULL tree */
 | |
| #define NULL_ACTION    ((void(*)()) NULL)
 | |
| #define NULL_TREE      ((AVLtree) NULL)
 | |
| 
 | |
| 
 | |
| /* BEGIN Internal definitions */
 | |
|        /* Directional Definitions */
 | |
| typedef  short  DIRECTION;
 | |
| #define  LEFT             0
 | |
| #define  RIGHT            1
 | |
| #define  OPPOSITE(x)     (1 - (x))
 | |
| 
 | |
| 
 | |
|        /* return codes used by avl_insert(), avl_delete(), and balance() */
 | |
| #define  HEIGHT_UNCHANGED       0
 | |
| #define  HEIGHT_CHANGED         1
 | |
| 
 | |
| 
 | |
|        /* Balance Definitions */
 | |
| #define  LEFT_HEAVY            -1
 | |
| #define  BALANCED               0
 | |
| #define  RIGHT_HEAVY            1
 | |
| #define  LEFT_IMBALANCE(nd)    ((nd)->bal < LEFT_HEAVY)
 | |
| #define  RIGHT_IMBALANCE(nd)   ((nd)->bal > RIGHT_HEAVY)
 | |
| 
 | |
| 
 | |
|   /* structure for a node in an AVL tree */
 | |
| typedef struct avl_node
 | |
| { struct avl_node  *subtree[2];		/* LEFT and RIGHT subtrees */
 | |
|   short       bal;			/* balance factor */
 | |
|   void *      data[1];			/* data on my back */
 | |
| } AVLnode, *AVLtree;
 | |
| 
 | |
| /* End Internal definitions */
 | |
| 
 | |
|   /* structure which holds information about an AVL tree */
 | |
| typedef struct avl_tree
 | |
| { AVLtree     root;           /* pointer to the root node of the tree */
 | |
|   long        count;          /* number of nodes in the tree */
 | |
| 			      /* function used to compare keys */
 | |
|   void	     *client_data;		/* arbitrary client data */
 | |
|   int         (*compar)(void *l, void*r, NODE type);
 | |
|   void        (*destroy)(void *data);
 | |
|   void*	      (*alloc)(void *cdata, size_t size);
 | |
|   void	      (*free)(void *cdata, void* data, size_t size);
 | |
|   int	      isize;	      /* item data size */
 | |
| } avl_tree, *AVL_TREE;
 | |
| 
 | |
| #define AVL_ENUM_MAX 32			/* balanced tree, allows for 2**32 */
 | |
| 					/* nodes */
 | |
| 
 | |
| typedef struct avl_enum
 | |
| { AVL_TREE tree;
 | |
|   int current;
 | |
|   AVLtree parents[AVL_ENUM_MAX];
 | |
| } avl_enum;
 | |
| 
 | |
| void *avlfindfirst(AVL_TREE tree, void *key, avl_enum *e);
 | |
| void *avlfindnext(avl_enum *e);
 | |
| void  avlfinddestroy(avl_enum *e);
 | |
| 
 | |
|      /* Constructor and Destructor functions for AVL trees:
 | |
|      *          avlfree is a macro for avldispose in the fashion
 | |
|      *          of free(). It assumes certain default values
 | |
|      *          (shown below) for the deallocation function and
 | |
|      *          for the order in which children are traversed.
 | |
|      */
 | |
| extern AVL_TREE     avlinit(AVL_TREE tree,
 | |
| 			    void *cdata, size_t isize,
 | |
| 			    int (*compare)(void *l, void*r, NODE type),
 | |
| 			    void (*destroy)(void *d),
 | |
| 			    void* (*alloc)(void *cdata, size_t bytes),
 | |
| 			    void (*free)(void *cdata, void *ptr, size_t size));
 | |
| extern void         avlfree(AVL_TREE tree);
 | |
| 
 | |
|        /* Routine for manipulating/accessing each data item in a tree */
 | |
| extern void      avlwalk(AVL_TREE,
 | |
| 			 void (*action)(void *data,
 | |
| 					SIBLING_ORDER order,
 | |
| 					NODE type,
 | |
| 					int level,
 | |
| 					int balance),
 | |
| 			 SIBLING_ORDER);
 | |
| 
 | |
| 
 | |
|        /* Routine for obtaining the size of an AVL tree */
 | |
| extern int       avlcount(AVL_TREE);
 | |
| 
 | |
| 
 | |
|        /* Routines to search for a given item */
 | |
| extern void    *avlins(AVL_TREE tree, void *data);
 | |
| extern int	avldel(AVL_TREE tree, void *data);
 | |
| extern void    *avlfind(AVL_TREE tree, void *data);
 | |
| 
 | |
| 
 | |
|        /* Routines to search for the minimal item of a tree */
 | |
| extern int	avldelmin(AVL_TREE tree, void *data);
 | |
| extern void     *avlfindmin(AVL_TREE tree);
 | |
| 
 | |
| 
 | |
|        /* Routines to search for the maximal item of a tree */
 | |
| extern int      avldelmax(AVL_TREE tree, void *data);
 | |
| extern void     *avlfindmax(AVL_TREE tree);
 | |
| 
 | |
| #endif /* AVL_H_INCLUDED */
 |