Mercurial > ~dholland > hg > ag > index.cgi
view anagram/support/agbaltree.h @ 16:f9e4689b837d
Some minor updates for 15 years later.
author | David A. Holland |
---|---|
date | Tue, 31 May 2022 01:45:26 -0400 |
parents | 13d2b8934445 |
children |
line wrap: on
line source
/********************************************************** The AnaGram Class Library The AgBalancedTree Class Copyright 1997 Parsifal Software. All Rights Reserved. See the file COPYING for license and usage terms. ***********************************************************/ #ifndef AGBALTREE_H #define AGBALTREE_H #include <stdlib.h> #include "port.h" #include "agcontainer.h" template <class T> class AgBalancedTree : public AgIndexedContainer<T> { public: // Define Node class Node { public: Node *left, *right; T data; unsigned count; Node (const T &t); ~Node(); void resetCount(); T &locate(const unsigned x) const; void *operator new(size_t); void operator delete(void *); }; Node *root; virtual int compare(const T &x, const T &y) const; // Process methods int insert(const T &target, Node *&node); int identify(T &target, Node *&node); int identify(T *&target, Node *&node); int remove(const T &target, Node *&node); int includes(const T &target, Node *node) const; int lookup(T &target, Node *node) const; void rotateLeft(Node *&node); void rotateRight(Node *&node); Node *extractMin(Node *&node); Node *extractMax(Node *&node); // default comparison function public: AgBalancedTree() : AgIndexedContainer<T>(), root(0) {} virtual ~AgBalancedTree(); int insert(const T &t); int identify(T &t); int identify(T *&t); int remove(const T &t); int includes(const T &t) const; int lookup(T &t) const; AgBalancedTree<T> &reset(); unsigned size() const; void *operator new(size_t n) { return malloc(n); } void operator delete(void *p) { free(p); } const T &operator [] (const unsigned x) const { return root->locate(x); } T &operator [] (const unsigned x) { return root->locate(x); } AgBalancedTree<T> operator + (AgBalancedTree<T> &x); AgBalancedTree<T> operator * (AgBalancedTree<T> &x); AgBalancedTree<T> &operator *= (AgBalancedTree<T> &x); AgBalancedTree<T> operator - (AgBalancedTree<T> &x); int operator < (const AgBalancedTree<T> &) const; }; #endif /* AGBALTREE_H */