关于二叉树的深度算法题目及解答

求二叉树的深度算法

算法的思想:

  采用二叉树的后序遍历非递归算法。由于后序遍历非递归算法使用一个栈实现,每次都会在一条路径上走到最底层才向上访问,再向右访问。因此,记录下栈在遍历中的最大值,即为二叉树的最大深度。

#include <iostream>
#include <stack>
using namespace std;
struct BinTree
{
    int data;
    BinTree *lc;
    BinTree *rc;
}BTNode,*BinTree;
int max(int a,int b)
{
    return (a>b)?a:b;
}
int BinTreeDepth(BinTree T)
{
    stack<BinTree> s;
    BinTree p = T,r = NULL;
    int depth=0;
    while(p||!s.empty())
    {
        if(p)
        {    //从根节点向左边走
            s.push(p);
            int size = s.size();//获取栈的大小
            depth = max(depth,size);//替换最大值
            p = p->lc;
        }
        else
        {    //左边走不通向右走
            p = s.top();
            if(p->rc&&p->rc!=r)//如果右子树存在,且未被访问过
            {
                p = p->rc;
                s.push(p);
                int size = s.size();//获取栈的大小
                depth = max(depth,size);//替换最大值
                p = p->lc;
            }else
            {
                p=s.top();
                s.pop();
                cout<<p->data<<endl;
                r=p;            //记录最近访问的节点
                p=NULL;            //节点访问完之后,重置p指针,目的是为了防止再次将左孩子压栈
            }
        }
    }
    return depth;
}

求二叉树深度的算法

题目:二叉树用二叉链表表示,编写求二叉树深度的算法。

答案是:

int height(Bitree T)
{
  if (T==NULL) return 0;
  u=height(T->lchild);
  v=height(T->rchild);
   if (u>n) return (u+1)
  return (v+1)
}

关于递归,你可以看成是一句一句往下运行嘛。需要保存状态的时候,系统就会自动用栈帮你保存。就依你说得那个为例:
n为全局变量,初值为0;

第一次调用height(T),假设T!=NULL
由于T!=NULL:跳过if (T==NULL) return 0;

关键到了u=height(T->lchild); 调用本身的函数:此时的T->lchild保存在栈中,既然是调用就得从函数开头执行:
看下这时候T2(其实就是T->lchild),if (T==NULL) return 0;
这里假设T不是NULL,就继续运行在遇到u=height(T->lchild); 在调这个函数本身——
这里就假设它为T->lchild==NULL吧。这下可好,这个函数执行return 0;

慢着:第二次函数调用u=height(T->lchild)中的函数值已经计算出来啦。这时u=0;

你还记得第二次调用运行到了v=height(T->rchild); 这句话吧?好,这个过程就和u=height(T->lchild)完全一样。
这里也假设得到的v=0

则第二次调用到了if (u>n) return (u+1)
return (v+1)
得到一个返回值,不如就假设u〉n,于是返回值1;
好,这一波完毕;

你还记得第一次调用的height吧,这时把返回值给u,u=1;
然后执行到第一次调用中的v=height(T->rchild); 了。分析同上。

这个过程的确比较复杂。慢慢琢磨吧。呵呵。

 基本思路就是如果当前节点还有子节点,则继续访问,递归的找寻子节点直到叶子节点为止。

procedure tree(a:node,depth:integer); 
begin 
if result<depth then result:=depth; 
if a.leftchild<>nil then tree(a.leftchild,depth+1); 
if a.rightchild<>nil then tree(a.rightchild,depth+1); 
end;

注:result是全局变量,是结果

实际上最好不用什么全局变量 

int depth(node *bt) 
{ if (bt==NULL) 
return 0; 
ldepth=depth(bt->left)+1; 
rdepth=depth(bt->right)+1; 
return max(ldepth,rdepth); 
}

全局变量是bug 

int Height(BiTree T){ 
int m,n; 
if(!T) return(0); 
else 
m=Height(T->lchild); 
n=Height(T->rchild); 
return((m>n?m:n)+1); 
}

求树深度的递归算法 

// struct bnode{struct bnode *lc,*rc); 
int depth(struct bnode *r) 
{ 
return r==NULL?0:1+max(depth(r->lc),depth(r->rc)); 
}

问:设计算法求二叉树的深度

设一棵二叉树以二叉链表存储,试设计算法求此二叉树的深度

回答:

#include <stdio.h>
#include <stdlib.h>
typedef struct node
{
 char data;
 struct node *left,*right;
}Node,*PNode;
PNode createBtree(PNode root)//创建二叉树,控制台下输入,基于先序遍历输入
{
   char data;
   scanf("%c",&data);
   if (data==' ')
   {
    root=NULL;
    return root;
   }
   root = (PNode)malloc(sizeof(Node));
   root->data = data;
   root->left = createBtree(root->left);
   root->right = createBtree(root->right);
   return root;
}
int depth(PNode root)//这就是你要的函数。
{
 int ld,rd;
 if (root==NULL)
 {
  return 0;
 }
 ld = 1+depth(root->left);
 rd = 1+depth(root->right);
 return ld>rd?ld:rd;
}
int main()
{
    PNode root=NULL;
 root = createBtree(root);
 printf("%d",depth(root));
 return 0;
}

为了测试,写了二叉树的建立程序;
如下输入可以看到结果
虚节点用空格输入的。例如你输入
先序遍历
234空格空格5空格6空格空格7空格空格回车就可以看到结果。
另外,本算法是从1开始算深度的,就是根节点是深度下。

以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索算法
, 递归
, int
, struct
, 函数
变量
二叉树深度算法、求二叉树深度的算法、二叉树的深度算法、二叉树的深度递归算法、设计算法求二叉树深度,以便于您获取更多的相关知识。

时间: 2024-09-18 10:33:37

关于二叉树的深度算法题目及解答的相关文章

max hl-数据结构二叉树求二叉树深度算法

问题描述 数据结构二叉树求二叉树深度算法 c:documents and settingsadministratoroo.cpp(79) : error C2065: 'max' : undeclared identifier

[华为机试练习题]42.求二叉树的深度和宽度

题目 题目标题: 求二叉树的宽度和深度 给定一个二叉树,获取该二叉树的宽度和深度. 例如输入 a / \ b c / \ / \ d e f g 返回3. 接口说明 原型: int GetBiNodeInfo(BiNode &head, unsigned int *pulWidth, unsigned int *pulHeight) 输入参数: head 需要获取深度的二叉树头结点 输出参数(指针指向的内存区域保证有效): pulWidth 宽度 pulHeight 高度 返回值: 0 成功 1

c语言-数据结构C语言版10道实习题目求解答!!

问题描述 数据结构C语言版10道实习题目求解答!! 除有特别说明外,每个题目请以自然语言.形式化表述(伪码.流程图等).程序代码三种方式描述. 顺序结构线性表LA与LB的节点关键字为整数.LA与LB的元素按非递减有序,线性表空间足够大.试给出一种高效算法,将LB中的元素合并到LA中,使新的LA元素仍保持非递减有序.高效是指最大限度的避免移动元素. 请写一个算法将线性表(a1,a2,-,an)逆置为(an,an-1,-,a1). 在一个递增有序的线性表中,有数值相同的元素存在.若存储方式为单链表,

剑指Offer之二叉树的深度

[题目] 题目描述: 输入一棵二叉树,求该树的深度.从根结点到叶结点依次经过的结点(含根.叶结点)形成树的一条路径,最长路径的长度为树的深度. 输入: 第一行输入有n,n表示结点数,结点号从1到n.根结点为1. n <= 10. 接下来有n行,每行有两个个整型a和b,表示第i个节点的左右孩子孩子.a为左孩子,b为右孩子.当a为-1时,没有左孩子.当b为-1时,没有右孩子. 输出: 输出一个整型,表示树的深度. 样例输入: 32 3-1 -1-1 -1 样例输出: 2 [解析] 通过递归,迭代计算

c语言题目求解答~~~~~

问题描述 c语言题目求解答~~~~~ 自然数列1,2,3,4,5,......大家都很熟悉,现将自然数列写成一排,数字中间不留空格等任何分隔符号就成了如下这样123456789101112131415161718192021......这是一个很长很长的串,现要求在这个串中找到一个最先出现给定子串的位置.例如给定子串1112,这该子串最先出现在串中第12个字符位置为了能简化处理,我们保证评判时给定的子串在串中一定出现,且位置不大于10000. 输入格式 给定的子串(一行由数字字符构成的字符串,不

一道关于数组的算法题目,请用java实现。

问题描述 一道关于数组的算法题目,请用java实现. 在这个图片里我们有不同高度的墙.这个图片由一个整数数组所代表,数组中每个数是墙的高度.上边的图可以表示为数组[2,5,1,2,3,4,7,7,6]. 假如开始下雨了,那么墙之间的水坑能够装多少水呢? 请用java实现(任意数组求出结果) 解决方案 参考这三个贴 http://www.cnblogs.com/xiangnan/archive/2013/11/01/3402467.html http://blog.jobbole.com/5070

算法题目,求解,赶时间,在线等!

问题描述 算法题目,求解,赶时间,在线等! 长跑接力赛全程m公里,规定:每个队5人,每个人都必须而且只能跑一次,并且至少跑1公里.最多跑n公里,接力点必须在整公里处.刘教练挑选了5名队员,测试后得到每个人连续跑1.2.3.--.n公里的最短时间.他准备精心安排每个队员跑的公里数,使全队完成接力赛用时最短.你能帮教练做一个最佳方案吗?(数据保证最佳方案唯一) (设:每人连续跑的路程越长速度越慢,若有保持速度的,也绝不会变快.) [输入]m n (m≦5000,n≤1000) 下接5行,每行n个整数

java-一道ava算法题目。。。。。

问题描述 一道ava算法题目..... 写一个函数来从数组中删除重复的对象.维持秩序.例如,如果输入的数组[ 1,5,4,2,7,2,6,5 ],结果应该是[ 1,5,4,2,7,6 ].实施时应执行速度的优化. 解决方案 其实你可以用set啊,set里的数据都是不能重复的 ps: List就是可以重复的集合.而Set是不可以重复的. 假如你输入1,2,2,4 那么在List集合中就有4个元素:1,2,2,4 但如果在Set集合中就只有3个元素了:1,2,4

分享Java面试中遇到的一些经典算法题目

问题描述 1.写一个方法,用一个for循环打印九九乘法表/***打印九九乘法口诀表*/publicvoidnineNineMulitTable(){for(inti=1,j=1;j<=9;i++){System.out.print(i+"*"+j+"="+i*j+"");if(i==j){i=0;j++;System.out.println();}}} 2.给定一个java.util.Date对象,如何转化为"2007-3-222