6-156 二叉树的深度

该博客介绍了如何实现计算二叉树深度的函数,详细阐述了二叉树的二叉链表存储结构,并提供了函数接口定义、裁判测试程序样例、输入样例和输出样例,帮助理解算法的实现过程。
摘要由CSDN通过智能技术生成

要求实现函数,计算并返回二叉树的深度。二叉树采用二叉链表存储,结点结构如下:

struct BiTNode {               // 结点结构
    char data;                 // 结点数据域
    BiTNode *lchild, *rchild;  // 左、右孩子指针
};

函数接口定义:

int Depth(BiTNode *T );

其中参数 T是指向根结点的指针。

裁判测试程序样例:

#include<iostream>
#include<string>
using namespace std;

struct BiTNode {
    char data;
    BiTNode *lchild, *rchild;
};

int Depth(BiTNode *T );            // 二叉树深度
BiTNode *CreateBiTree(string &s);  // 创建二叉树,s存放带虚结点的先序遍历序列

// 根据带虚结点的先序序列创建二叉树并输出其深度
int main() {
    string s;
    while(cin>>s) {
        BiTNode* root=CreateBiTree(s);
        cout<<Depth(root)<<endl;
    }
    
    return 0;
}

输入样例:

HDA**C*B**GF*E***
-+a**xb**-c**d**/e**f**
  • 10
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值