IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 游戏开发 -> 计算二叉树的深度和宽度 -> 正文阅读

[游戏开发]计算二叉树的深度和宽度

计算二叉树的最大深度和最大宽度

#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#define MaxSize 500             //假设循环队列足够长,因为下面要用到Q.rear来计算每一层的宽度

typedef struct BiTNode{
    char data[5];
    struct BiTNode *lchild,*rchild;
}BiTNode,*BiTree;
typedef struct SqQueue{
    BiTNode *t[MaxSize];
    int rear,front;
}SqQueue;

int Length(BiTree T);
BiTNode *CreateBiTree();
int high(BiTree T);
int main(){
	BiTNode *p=CreateBiTree();
	int l=Length(p);
	int h=high(p);
	printf("the length:%d\nthe high:%d",l,h);
	return 0;
}
//构造二叉树有很多的方法(例如递归等等),这里我是用了最笨的一种方法
BiTNode *CreateBiTree(){
    BiTNode *T=(BiTNode *)malloc(sizeof(BiTNode));
    strcpy(T->data,"A");
   
	BiTNode *p=(BiTNode *)malloc(sizeof(BiTNode));
	strcpy(p->data,"B");
	T->lchild=p;
   
    p=(BiTNode *)malloc(sizeof(BiTNode));
	strcpy(p->data,"C");
	T->rchild=p;
  
    p=(BiTNode *)malloc(sizeof(BiTNode));
    strcpy(p->data,"D");
    T->lchild->lchild=p;
    T->lchild->lchild->lchild=NULL;
    T->lchild->lchild->rchild=NULL;
   
    p=(BiTNode *)malloc(sizeof(BiTNode));
    strcpy(p->data,"E");
    T->lchild->rchild=p;
    T->lchild->rchild->lchild=NULL;
    T->lchild->rchild->rchild=NULL;
  
    p=(BiTNode *)malloc(sizeof(BiTNode));
    strcpy(p->data,"F");
    T->rchild->lchild=p;
    T->rchild->lchild->lchild=NULL;
    T->rchild->lchild->rchild=NULL;
  
    T->rchild->rchild=NULL;

    return T;
}
//返回二叉树最大宽度
int Length(BiTree T){
    SqQueue Q;
    Q.rear=Q.front=0;           //队列初始化
    int lno[MaxSize];           //设一个数组存放层次遍历顺序下的每个结点所在的层号
    int Lno=0,max=0,n;
    BiTNode *p;
    if(T){
        Q.t[Q.rear]=T;       //根节点入队,等同于EnQueue(Q,T)入队操作
        lno[Q.rear]=1;              //根节点所在的那一层为第1层
        Q.rear++;
        while(Q.front!=Q.rear){     //当队列非空时循环继续
            p=Q.t[Q.front];    //p指向出队结点,等同于DeQueue(Q,p)出队操作
            Lno=lno[Q.front];  //本函数的核心语句,Lno用来存放当前结点的层次号
            Q.front++;
            if(p->lchild){
                Q.t[Q.rear]=p->lchild;
                lno[Q.rear]=Lno+1; //根据当前结点的层次号算出其孩子结点的层次号,也就是孩子结点比父结点多一层,加一即可
                Q.rear++;
            }
            if(p->rchild){
                Q.t[Q.rear]=p->rchild;
                lno[Q.rear]=Lno+1; //根据当前结点的层次号算出其孩子结点的层次号,也就是孩子结点比父结点多一层,加一即可
                Q.rear++;
            }
        }       //while循环结束时,Lno变量存放的是二叉树的最大层数,顺道把二叉树的深度也给求出来了
        for(int i=1;i<=Lno;i++){
            n=0;
            for(int j=0;j<Q.rear;j++){
                if(lno[j]==i){
                    n++;                //统计相同层号的结点数
				}
            }
            if(max<n){                  //max变量记录最大的结点数,也就是宽度!!!
                max=n;
            }
        }
        return max;
    }else{
        return 0;
    }
}
//返回最大高度
int high(BiTree T){
	int m,n;
	if(T){
		m=high(T->lchild);
		n=high(T->rchild);
		return m>n?m+1:n+1;
	}else{
		return 0;
	}
	
	
	
}

程序运行截图:
在这里插入图片描述

  游戏开发 最新文章
6、英飞凌-AURIX-TC3XX: PWM实验之使用 GT
泛型自动装箱
CubeMax添加Rtthread操作系统 组件STM32F10
python多线程编程:如何优雅地关闭线程
数据类型隐式转换导致的阻塞
WebAPi实现多文件上传,并附带参数
from origin ‘null‘ has been blocked by
UE4 蓝图调用C++函数(附带项目工程)
Unity学习笔记(一)结构体的简单理解与应用
【Memory As a Programming Concept in C a
上一篇文章      下一篇文章      查看所有文章
加:2022-03-21 21:25:47  更:2022-03-21 21:25:53 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/16 18:35:56-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码