📄 pers_tree.h
字号:
/*******************************************************************************++ LEDA 4.5 +++ pers_tree.h+++ Copyright (c) 1995-2004+ by Algorithmic Solutions Software GmbH+ All rights reserved.+ *******************************************************************************/// $Revision: 1.3 $ $Date: 2004/02/06 11:19:13 $#ifndef LEDA_PERS_TREE_H#define LEDA_PERS_TREE_H#include <LEDA/basic.h>#include <LEDA/list.h>LEDA_BEGIN_NAMESPACEtypedef void (*DRAW_NODE_FCT)(double,double,void*);typedef void (*DRAW_EDGE_FCT)(double,double,double,double);/* implementation of a node of the ephemeral red-black tree of a specific * persistent node, where the colors of that persistent node through the * various versions can be found */class pers_tree_node;class C_pers_tree_node;class F_pers_tree_node;class VER_pers_tree_node;typedef list_item Version; class __exportC C_pers_tree_node{ friend class __exportC pers_rb_tree; Version vers_stamp; C_pers_tree_node* c_link[3]; int c_right; int c_color; int col_value; LEDA_MEMORY(C_pers_tree_node)};/* implementation of a node of the ephemeral red-black tree of a specific * persistent node, where the children of that persistent node through the * various versions can be found */ class __exportC F_pers_tree_node{ friend class __exportC pers_rb_tree; Version ver_stamp; F_pers_tree_node* f_link[3]; int f_right; int f_color; pers_tree_node* poin_value; LEDA_MEMORY(F_pers_tree_node)};/* implementation of a persistent node */class __exportC pers_tree_node{ friend class __exportC pers_rb_tree; void *key; void *inf; pers_tree_node *parent; int right; int is_leaf; F_pers_tree_node *link[2]; C_pers_tree_node *red; F_pers_tree_node *copy; pers_tree_node* next; // linking all used pers_tree_nodeS LEDA_MEMORY(pers_tree_node)};/* implementation of a node (or member) of the version list */class __exportC VER_pers_tree_node{ friend class __exportC pers_rb_tree; pers_tree_node* acc_pointer; int popul; double ser_num; LEDA_MEMORY(VER_pers_tree_node)};typedef VER_pers_tree_node* ver_node;struct V_LIST {list<ver_node> vl;int count;pers_tree_node* used;};class __exportC pers_rb_tree {protected:V_LIST* v_list;virtual int cmp_keys(GenPtr, GenPtr) const { return 0; }virtual void print_key(GenPtr) const {}virtual void copy_key(GenPtr&) const {}virtual void copy_inf(GenPtr&) const {}virtual void clear_key(GenPtr&) const {}virtual void clear_inf(GenPtr&) const {} pers_tree_node* child(int leftright, pers_tree_node *p, Version i) const{ return(acc_step(p->link[leftright], i)); }GenPtr get_key(pers_tree_node *p, Version i) const{ return (acc_step(p->copy, i))->key; }int isleaf(pers_tree_node *p) const{ //return (p == p->link[0]->poin_value); return p->is_leaf; } pers_tree_node* sibling(pers_tree_node *p, Version i) const{ return acc_step(p->parent->link[1 - p->right], i); } /* define the order of versions in the version list */int vless(Version x, Version y) const{ return (v_list->vl[x]->ser_num < v_list->vl[y]->ser_num); }/* find the next to a given version in the version list */ Version iplus(Version i) const{ return v_list->vl.succ(i); }pers_tree_node* acc_step(F_pers_tree_node *, Version) const;Version new_version(Version);void m_b_root(Version);F_pers_tree_node* f_nleaf(pers_tree_node*, Version);F_pers_tree_node* f_nnode(F_pers_tree_node*, F_pers_tree_node*);F_pers_tree_node* f_rbsearch(F_pers_tree_node* p, Version) const;void f_rbclear(F_pers_tree_node*);int f_insert(F_pers_tree_node*, pers_tree_node*, Version);void f_single_rot(F_pers_tree_node*, int);void f_double_rot(F_pers_tree_node*, int);C_pers_tree_node* c_nleaf(int, Version);C_pers_tree_node* c_nnode(C_pers_tree_node*, C_pers_tree_node*);C_pers_tree_node* c_rbsearch(C_pers_tree_node* p, Version) const;void c_rbclear(C_pers_tree_node*);int c_insert(C_pers_tree_node*, int, Version);void c_single_rot(C_pers_tree_node*, int);void c_double_rot(C_pers_tree_node*, int);pers_tree_node* single_rot(pers_tree_node* top_node, int dir, Version i);pers_tree_node* double_rot(pers_tree_node* top_node, int dir, Version i);pers_tree_node* newnode(pers_tree_node* c1, pers_tree_node* c2, Version i);pers_tree_node* newleaf(void* val, void* inf, pers_tree_node*, pers_tree_node*, Version i);int isred(pers_tree_node* p, Version i) const;void up_col(C_pers_tree_node* p, int newvalue, Version i);void update(F_pers_tree_node* p, pers_tree_node* newvalue, Version i);pers_tree_node* search(void* val, Version i) const { pers_tree_node* p; return search(val,p,i);}pers_tree_node* search(void*, pers_tree_node*&, Version) const;public: pers_rb_tree() {}virtual ~pers_rb_tree() {}void init_tree();const GenPtr& key(pers_tree_node* p) const { return p->key; }const GenPtr& inf(pers_tree_node* p) const { return p->inf; }Version copy_version(Version);void del_version(Version);Version del(void*, Version);Version insert(void*, void*, Version);Version change_inf(pers_tree_node*,void*,Version);pers_tree_node* lookup(void *val,Version v) const;pers_tree_node* locate(void *val,Version v) const;pers_tree_node* locate_pred(void *val,Version v) const;pers_tree_node* min(Version v) const;pers_tree_node* max(Version v) const;pers_tree_node* succ(pers_tree_node* p, Version v) const { return child(1,p,v);}pers_tree_node* pred(pers_tree_node* p, Version v) const { return child(0,p,v);}int size(Version v) const { return v_list->vl[v]->popul; }double ver_num(Version v) const { return v_list->vl[v]->ser_num; }void print(pers_tree_node*,Version) const;void del_tree();void print(Version v) const{ //cout << string("%5f : ",v_list->vl[v]->ser_num); print(v_list->vl[v]->acc_pointer,v); cout << endl; }void draw(DRAW_NODE_FCT,DRAW_EDGE_FCT, Version, pers_tree_node*, double, double, double, double, double) const;void draw(DRAW_NODE_FCT,DRAW_EDGE_FCT, Version, double, double, double, double)const;};LEDA_END_NAMESPACE#endif
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -