| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 362 人关注过本帖
标题:关于平衡二叉树的一句代码不是很理解
只看楼主 加入收藏
yuanhaitaozz
Rank: 1
来 自:江苏
等 级:新手上路
帖 子:32
专家分:9
注 册:2013-8-22
结帖率:100%
收藏
 问题点数:0 回复次数:0 
关于平衡二叉树的一句代码不是很理解
程序代码:
void LeftBalance(PBSTree* T)
{
    PBSTree lc,rd;
    lc = (*T)->lchild;
    switch (lc->bf)
    {
    case LH:
        (*T)->bf = lc->bf = EH;
        R_Rotate(T);
        break;
    case RH:
        rd = lc->rchild;
        switch(rd->bf)
        {
        case LH:
            (*T)->bf = RH;
            lc->bf = EH;
            break;
        case EH:
            (*T)->bf = lc->bf = EH;
            break;
        case RH:
            (*T)->bf = EH;
            lc->bf = LH;
            break;
        }
        rd->bf = EH;
        L_Rotate(&(*T)->lchild);
        R_Rotate(T);
        break;
    }
} 
在第二层switch中 的 case EH 这句代码 我并不理解。
因为如果要执行左平衡,那树的深度是肯定要改变的(但树的深度改变并不一定就会执行左平衡)
但是rd->bf=EQ 就意味着深度没有改变 在我看来是不会出现这种情况的啊。。。
还是我哪里理解错了  谢大家帮我解释解释吧  困了一天了
搜索更多相关主题的帖子: 二叉树 平衡 
2014-04-17 00:18
快速回复:关于平衡二叉树的一句代码不是很理解
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.015087 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved