2019-05-04 BST,AVT,huffman零碎知识小记

1.哈夫曼树的权值要是正数,这是根据408考题得出的结论
2.对于一个BST或者AVT,它的查找长度在查找失败的情况下是到达虚拟的查找失败结点的父节点的长度
如图:若查找第一个失败的虚拟结点,那么查找长度是3,不是4


image.png

3.判断关键字路径是否符合二叉排序树的要求,可以做出路径图,然后比较是否是满足要求的路径(左右子树和根节点的大小)
4.平衡二叉树最后插入的结点不一定是叶子结点,因为可能会进行平衡调整
5.度为m的哈夫曼树,任何一个结点的度只能是0或者m
6.一个二叉排序树最好的方向是接近一个二分查找的判定树
7.大根堆的特点:根节点的关键字大于等于左右子树的关键字;大根堆是完全二叉树

几个算法题代码

/*判断一棵树是否是二叉排序树*/
算法思想:使用二叉树中序遍历的思想,每次记录前一个结点的指针,
        若满足后面访问的结点关键值大于前一个访问的结点的关键字值
失分点:没有处理相同关键值的情况,T->key<=pre->key

bool IsBST(BiTree T, BSTNode *pre)
{
    if (T) {
        if (!IsBST(T->lchild, pre))
            return false;
        /*pre在访问第一个结点之前为NULL,然后依次记录每个访问的结点指针*/
        if (pre != NULL && T->key < pre->key)
            return false;
        else
            pre = T;
        if (!IsBST(T->rchild, pre))
            return false;
    }
    return true;
}
参考方法:
KeyType predt = -32767;
使用全局变量记录pre,但是不是那么的合适似乎

bool JudgeBST(BiTree bt) 
{
    int b1, b2;
    if (bt == NULL)
        return true;
    else {
        b1 = JudgeBST(bt->lchild);
        if (b1 == 0)
            return false;
        if (predt >= bt->data)
            return false;
        b2 = JudgeBST(bt->rchild);
        if (b1 == 0)
            return false;
        return true;
    }
}
int level(BiTree bt, BSTNode *p)
{
    int dep = 1;
    while (p->key != bt->key) {
        dep++;
        if (p->key < bt->key)
            bt = bt->lchild;
        else
            bt = bt->rchild;
    }
    return dep;
}
参考方法:
int level(BiTree bt, BSTNode *p)
{
    int n = 0;
    BiTree t = bt;
    if (bt != NULL) {
        n++;
        while (t->data != p->data) {
            if (p->data < t->data)
                t = t->lchild;
            else
                t = t->rchild;
            n++;
        }
    }
    return n;
}
bool IsAVT(BiTree bt, int &h)
{
    if (bt) {
        int h1 = 0, h2 = 0;
        if (!IsAVT(bt->lchild)) //判断左子树是不是平衡树
            return false;
        if (!IsAVT(bt->rchild)) //判断右子树是不是平衡树
            return false;
        if (h1 - h2 >= 2 || h2 - h1 >= 2) //判断当前树是不是平衡树
            return false;
    }
    return true;
}
参考方法:
采用前序遍历的递归算法(我修改了代码风格,便于阅读)
void Judeg_AVT(BiTree bt, int &balance, int &h)
{
    int bl, br, hl, hr;
    if (bt == NULL) {
        balance = 1;
        h = 0;
    }
    else if(bt->lchild==NULL && bt->rchild==NULL) {
        balance = 1;
        h = 1;
    }
    else {
        Judeg_AVT(bt->lchild,bl,hl);
        Judeg_AVT(bt->rchild,br,hr);
        if (h1 > h2)
            h = h1 + 1;
        else
            h = h2 + 1;
        if (h1 - h2 <= 1 || h2 - h1 <= 1)
            h = hl & hr;
        else
            h = 0;
    }
}
参考方法:

KeyType MinKey(BiTree bt)
{
    while (bt->lchild != NULL)
        bt = bt->lchild;
    return bt->data;
}

KeyType MaxKey(BiTree bt)
{
    while (bt->rchild != NULL)
        bt = bt->rchild;
    return bt->data;
}
算法思想:
1.使用正常的中序遍历,>=k结果保存到栈中,然后输出
2.使用RNL的遍历次序,这样可以先输出最大值,然后最小值

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

推荐阅读更多精彩内容