静下心来写算法(之二叉树)

相信大家考计算机二级时都背过这个关于二叉树的概念,不过只有自己动手写出来时才会发现它的奇妙之处。
先巩固一下概念:
二叉树的每个结点至多只有二棵子树(不存在度大于2的结点),二叉树的子树有左右之分,次序不能颠倒。二叉树的第i层至多有2^{i-1}个结点;深度为k的二叉树至多有2^k-1个结点;对任何一棵二叉树T,如果其终端结点数为n_0,度为2的结点数为n_2,则n_0=n_2+1


1)二叉树数据结构 
typedef struct node{
        char data;
        struct node *left;
        struct node *right;
}BT;
2)创建测试用的二叉树
BT *creat_test()
{
/*
        A
       / \
      B   C
         /
        D
         \
          E
*/
        BT *pA=(BT *)malloc(sizeof(BT));
        BT *pB=(BT *)malloc(sizeof(BT));
        BT *pC=(BT *)malloc(sizeof(BT));
        BT *pD=(BT *)malloc(sizeof(BT));
        BT *pE=(BT *)malloc(sizeof(BT));
        pA->data='A';
        pB->data='B';
        pC->data='C';
        pD->data='D';
        pE->data='E';
        pA->left=pB;
        pA->right=pC;
        pB->left=NULL;
        pB->right=NULL;
        pC->left=pD;
        pC->right=NULL;
        pD->left=NULL;
        pD->right=pE;
        pE->left=NULL;
        pE->right=NULL;
        return pA;
}
3)递归先序创建二叉树 
BT *creat_tree()
{
        char ch;
        BT *t;
        // printf("\n请输入二叉树的元素:\n");
        fflush(stdin);
        ch=getchar();
        if(ch=='#'){
                t=NULL;
        }else{
                t=(BT *)malloc(sizeof(BT));
                assert(NULL!=t); 
                t->data=ch;
                t->left=creat_tree();
                t->right=creat_tree();
        }
        return t;
}
4)先序遍历:根左右 
void pre_traverse(BT *btree)
{
        if(btree){
                printf("%c\t",btree->data);
                pre_traverse(btree->left);
                pre_traverse(btree->right);
        }
}
5)中序遍历:左根右 
void in_traverse(BT *btree)
{
        if(btree){
                in_traverse(btree->left);
                printf("%c\t",btree->data);
                in_traverse(btree->right);
        }
}
6)后序遍历:左右根
void post_traverse(BT *btree)
{
        if(btree){
                post_traverse(btree->left);
                post_traverse(btree->right);
                printf("%c\t",btree->data);
        }
}
7)获取叶子节点的个数 
int leaf_count(BT *btree)
{
        if(btree){
                leaf_count(btree->left);
                leaf_count(btree->right);
                if(btree->left==NULL && btree->right==NULL){
                        num++;
                }
        }
        return num;
}
8)获取二叉树深度 
int depth_tree(BT *btree)
{
        int hl,hr,hm;
        if(btree){
                hl=depth_tree(btree->left);
                hr=depth_tree(btree->right);
                hm=hl>hr?hl:hr;
                return(hm+1);
        }else{
                return 0;
        }
} 
9)打印叶子节点 
void print_leaf(BT *btree)
{
        if(btree){
                if(btree->left==NULL && btree->right==NULL){
                        printf("%c\t",btree->data);
                }
                print_leaf(btree->left);
                print_leaf(btree->right);
        }
}




  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值