Tree

depth:n的depth为从root到n的路径的长度
height:n的height为从n到一个leaf的最长路径长度。树的height等于root的depth

preorder traversal: 遍历顺序,根,左子树,右子树
postorder traversal: 遍历顺序,左子树,右子树,根
inorder traversal: 遍历顺序, 左子树,根,右子树

  • Bineary search tree
    average depth = O(logN)
    worst case depth is O(N)
    implementation:
struct BinaryNode
{
    Object element; //The data in the node
    BinaryNode *left; //Left child
    BinaryNode *right; //Right child
};

contains:

/*Internam method to test if an item is in a subtree
  * x is itemto search for.
  * t is the node that roots the subtree
*/
bool contains(const Comparable & x, BinaryNode *t) const
{
    if (t == NULL) return false;
    else if (x < t->element) return contains(x, t->left);
    else if (x > t->element) return contains(x, t->right);
    else return true; //match
}

findMin and findMax (recursion and iteration implementation):

//recursion, return node containing the smallest item
BinaryNode * findMin(BinaryNode *t) const
{
    if(t == NULL) return NULL;
    if(t->left == NULL) return t;
    return findMin(t->left);
}
//iteration, return node containing the largest item
BinaryNode * findMax(BinaryNode *t) const
{
    if(t != NULL)
    {
        while (t->right != NULL)
        {
          t = t->right;
        }
    }
    return t;
}

insert:

/* x is the item to nsert
   t is the node that roots the subtree
   set the new root of the subtree
*/
void insert(const Comparable & x, BinaryNode * &t)
{
    if(t == NULL) t = new BinaryNode(x, NULL, NULL);
    else if (x < t->element) insert(x, t->left);
    else if (x > t->element) insert(x, t->right);
    else ; //duplicate, do nothing
}

remove:
需要考虑多种情况。
如果结点是树叶,可以直接删除。
如果结点有一个child,删除后将child与父结点连接,如下


Paste_Image.png

如果结点有两个child,一般的删除策略是用其右字数中的最小数据代替该节点并递归地删除那个节点。例子如下


Paste_Image.png

实现:
//效率不高,因为沿树两次搜索来查找和删除右子树中的最小节点
//如要提高效率,需要写一个特殊的removeMin  
void remove(const Comparable & x, BinaryNode * &t)
{
    if(t == NULL) return; //item not found, do nothing
    if(x < t->element) remove(x,t->left);
    else if(x > t->element) remove(x,t->right);
    else if(t->left != NULL && t->right != NULL) //Two children
    {
        t->element = findMin(t->right)->element;
        remove(t->element,t->right);
    } 
    else //node has only one child
    {
        BinaryNode *oldNode = t;
        t = (t->left != NULL) ? t->left : t->right;
        delete oldNode;
    }
}

makeEmpty and destructor:

~BinarySearchTree()
{
    makeEmpty();
}
void makeEmpty(BinaryNode * &t)
{
    if (t != NULL)
    {
        makeEmpty(t->left);
        makeEmpty(t->right);
        delete t;
    }
    t = NULL; //important
}

operator= and clone:

//deep copy
const BinarySearchTree & operator=(const BinarySearchTree &rhs)
{
    if(this != &rhs)
    {
        makeEmpty();
        root = clone(rhs.root);
    }
    return *this;
}
//method to clone subtree
BinaryNode *clone(BinaryNode *t) const
{
    if(t == NULL) return NULL;
    return new BinaryNode(t->element,clone(t->left),clone(t->right));
}
  • Complexity analysis:
    average case:
    O(logN) for all operation
    actually O(d) for all operations except makeEmpty and operator=
    d = depth including the node visited
    worst case: O(N)

  • Tree traversal:
    O(N) complexity
    print tree in sorted order:

//inorder
void printTree(BinaryNode *t) const
{
    if(t != NULL)
    {
        printTree(t->left);
        cout << t->element << endl;
        printTree(t->right);
    }
}

compute height:

int height(BinaryNode *t)
{
    if(t == NULL) return -1;
    else return 1 + max(height(t->left),height(t->right));
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,456评论 5 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,370评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,337评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,583评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,596评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,572评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,936评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,595评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,850评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,601评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,685评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,371评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,951评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,934评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,167评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,636评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,411评论 2 342

推荐阅读更多精彩内容

  • 背景 一年多以前我在知乎上答了有关LeetCode的问题, 分享了一些自己做题目的经验。 张土汪:刷leetcod...
    土汪阅读 12,719评论 0 33
  • 1. AVL树 AVL树简单来说是带有平衡条件的二叉查找树.传统来说是其每个节点的左子树和右子树的高度最多差1(注...
    fredal阅读 1,824评论 0 4
  • 94. Binary Tree Inorder Traversal 中序 inorder:左节点->根节点->右节...
    Morphiaaa阅读 514评论 0 0
  • 每当清晨第一缕阳光打在露珠上的时候总会想起马尔江那句“妈妈,你看小草哭了”。 有人说要想追寻生命的意义,就是要任性...
    方辰阅读 845评论 2 4
  • 看到城楼的时候,惊觉它的矮小,只约三四米高,不似在影视中见到的高大威严。它真实的落在眼前,登楼不需几分,登高瞰半城...
    目觉阅读 490评论 2 3