43 lines
		
	
	
	
		
			1.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			43 lines
		
	
	
	
		
			1.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* $Id$ */
 | |
| 
 | |
| /* AVL-trees: trees in which the difference in depth
 | |
|    of the left branch and the right branch is at most one.
 | |
|    Information in the nodes is represented by a pointer, which is to
 | |
|    be supplied by the user. The user is also expected to supply a
 | |
|    comparison routine for each AVL tree. This routine is offered two
 | |
|    parameters, both pointers, and is expected to return:
 | |
|    a negative number	if the comparison result is <
 | |
|    0 			if the comparison result is =
 | |
|    a positive number	if the comparison result is >
 | |
| */
 | |
| 
 | |
| typedef struct avl_tree	*AVL_tree;
 | |
| 
 | |
| /* extern AVL_tree create_avl_tree(int (*cmp)());
 | |
|    Returns a fresh avl_tree structure. 'cmp' will be used as comparison
 | |
|    routine for this tree.
 | |
| */
 | |
| extern AVL_tree create_avl_tree();
 | |
| 
 | |
| /* extern add_to_avl_tree(AVL_tree tree, char *n);
 | |
|    Adds the information indicated by 'n' to the avl_tree indicated by 'tree'.
 | |
| */
 | |
| extern add_to_avl_tree();
 | |
| 
 | |
| /* extern char *find_ngt(AVL_tree tree, char *n);
 | |
|    Returns the information in the largest node that still compares <= to 'n',
 | |
|    or 0 if not present.
 | |
| */
 | |
| extern char *find_ngt();
 | |
| 
 | |
| /* extern char *find_nlt(AVL_tree tree, char *n);
 | |
|    Returns the information in the largest node that still compares >= to 'n',
 | |
|    or 0 if not present.
 | |
| */
 | |
| extern char *find_nlt();
 | |
| 
 | |
| /* extern char *find_eq(AVL_tree tree, char *n);
 | |
|    Returns the information in the node that compares equal to 'n',
 | |
|    or 0 if not present.
 | |
| */
 | |
| extern char *find_eq();
 |