当前位置: 首页 > news >正文

企业网站及公众号建设方案企业策划推广公司

企业网站及公众号建设方案,企业策划推广公司,网页首页设计模板图片,毕设帮做网站0.二叉树结点的链式存储结构 #include<stdio.h> #include<stdlib.h> #include<stdbool.h>typedef char TElemType;//树中元素基本类型为char类型//二叉树结点链式存储结构&#xff08;二叉链表&#xff09; typedef struct BiNode {TElemType data;//数据域…

0.二叉树结点的链式存储结构

#include<stdio.h>
#include<stdlib.h>
#include<stdbool.h>typedef char TElemType;//树中元素基本类型为char类型//二叉树结点链式存储结构(二叉链表)
typedef struct BiNode
{TElemType data;//数据域struct BiNode* lchild, * rchild;//左,右孩子指针
}BiNode,*BiTree;
//BiNode:用来定义结点类型
//BiTree:用来定义树类型

1.复制二叉树

int CopyBiTree(BiTree b,BiTree* newb)

注意:原本存在的树只是会遍历,不会被修改,故传入一级指针
但要复制成的新树,应传入结点指针的地址,即二级指针,因为要修改结点指针的值(指向新开辟的结点空间)

1.1算法步骤:

(1)返回条件:当前根结点为空,注意复制完空结点之后再返回
(2)当前结点非空,申请新结点空间并复制根结点
(3)递归复制左子树(注意传入New树待修改指针的地址)
(4)递归复制右子树(注意传入New树待修改指针的地址)

//1.先序复制二叉树      (万变不离其宗,就是先序遍历算法的变种)
//注意:原本存在的树只是会遍历,不会被修改,故传入一级指针
//但要复制成的新树,应传入结点指针的地址,即二级指针,因为要修改结点指针的值(指向新开辟的结点空间)
int CopyBiTree(BiTree b,BiTree* newb)
{//[1]返回条件:当前根结点为空,注意复制完空结点之后再返回if (b == NULL){(*newb) = NULL;//易错1:忘记复制空结点return 0;}//[2]当前结点非空,申请新结点空间,复制根结点(*newb) = (BiNode*)malloc(sizeof(BiNode));if (!(*newb)){printf("内存分配失败!\n");exit(-1);}(*newb)->data = b->data;//[3]递归复制左子树CopyBiTree(b->lchild, &((*newb)->lchild));//注意传入New树待修改指针的地址//[4]递归复制右子树CopyBiTree(b->rchild, &((*newb)->rchild));
}

2.计算二叉树的深度

  • 深度回顾:指从头结点开始到最远的叶子结点,路径上的结点数【注意:包括头结点】
int DepthBiTree(BiTree b)

注意:只进行遍历,不会修改树的结构,故传入一级指针

2.1算法步骤:

(1)返回条件:当前根结点为空,返回0
(2)递归计算左子树的深度记为m
(3)递归计算右子树的深度记为n
(4)返回子树的深度:即m和n中的较大值,并加1
加1是因为子树根结点要算上;
返回较大值是因为深度 应该是最远路径上的结点总数,

//2.计算二叉树深度  (树的深度:指从头结点开始到最远的叶子结点,路径上的结点数【注意:包括头结点】)
//注意:只进行遍历,不会修改树的结构,故传入一级指针
int DepthBiTree(BiTree b)
{//[1]返回条件:当前根结点为空,返回0if (b == NULL){return 0;}//[2]递归计算左子树的深度记为mint m = DepthBiTree(b->lchild);//[3]递归计算右子树的深度记为nint n = DepthBiTree(b->rchild);//[4]返回子树的深度:即m和n中的较大值,并加1//加1是因为子树根结点要算上return (m > n) ? m + 1 : n + 1;
}

3.计算二叉树中结点总数

int NodeCount(BiTree b)

3.1算法步骤:

(1)返回条件:当前根结点为空,返回0
(2)递归计算左子树的结点总数记为m
(3)递归计算右子树的结点总数记为n
(4)返回子树的结点总数:即m和n之和,并加1
加1是因为子树根结点要算上

//3.计算二叉树中结点总数
int NodeCount(BiTree b)
{//[1]返回条件:当前根结点为空,返回0if (b == NULL){return 0;}//[2]递归计算左子树的结点总数记为mint m = NodeCount(b->lchild);//[3]递归计算右子树的结点总数记为nint n = NodeCount(b->rchild);//[4]返回子树的结点总数:即m和n之和,并加1//加1是因为子树根结点要算上return m + n + 1;
}

4.计算二叉树中叶子结点总数

  • 回顾叶子结点:左子树和右子树均为空的结点,一般在完全二叉树的最下面
int LeadCountBiTree(BiTree b)

4.1算法步骤

(1)返回条件1:当前根结点为空,返回0
(2)返回条件2:当前结点为叶子结点,返回1
两个返回条件缺一不可
(3)递归计算左子树和右子树的叶子结点总数记为m和n
(4)返回子树的叶子结点总数:即m和n之和

//4.计算二叉树中叶子结点总数(叶子结点:左子树和右子树均为空的结点,一般在完全二叉树的最下面)
int LeadCountBiTree(BiTree b)
{//[1]返回条件1:当前根结点为空,返回0if (b == NULL){return 0;}//[2]返回条件2:当前结点为叶子结点,返回1if (b->rchild == NULL && b->lchild == NULL){return 1;}//[3]递归计算左子树和右子树的叶子结点总数记为m和nint m = LeadCountBiTree(b->lchild);int n = LeadCountBiTree(b->rchild);//[4]返回子树的叶子结点总数:即m和n之和return m+n;
}

5.整体代码实现

  • 样例树:应输入序列
    abc##de###fg#h###
  • 复制后新树的先序序列为:
    abcdefgh
  • 深度:4
  • 结点总数:8
  • 叶子结点总数:3
    在这里插入图片描述
#include<stdio.h>
#include<stdlib.h>
#include<stdbool.h>typedef char TElemType;typedef struct BiNode
{TElemType data;struct BiNode* lchild, * rchild;
}BiNode,*BiTree;//.先序遍历
bool PreOrderTraverse(BiTree b)
{if (b == NULL){return true;}printf("%c", b->data);//根PreOrderTraverse(b->lchild); //左PreOrderTraverse(b->rchild); //右}//先序建立整树
bool CreateBiTree(BiTree * b)
{//[0]TElemType ch;scanf_s("%c", &ch);if (ch == '#'){(*b) = NULL;}else{(*b) = (BiNode*)malloc(sizeof(BiNode));if (!(*b)){printf("内存分配失败!\n");exit(-1);}(*b)->data = ch;//根CreateBiTree(&((*b)->lchild)); //左CreateBiTree(&((*b)->rchild));//右}return true;
}//1.先序复制二叉树      (万变不离其宗,就是先序遍历算法的变种)
//注意:原本存在的树只是会遍历,不会被修改,故传入一级指针
//但要复制成的新树,应传入结点指针的地址,即二级指针,因为要修改结点指针的值(指向新开辟的结点空间)
int CopyBiTree(BiTree b,BiTree* newb)
{//[1]返回条件:当前根结点为空,注意复制完空结点之后再返回if (b == NULL){(*newb) = NULL;//易错1:忘记复制空结点return 0;}//[2]当前结点非空,申请新结点空间,复制根结点(*newb) = (BiNode*)malloc(sizeof(BiNode));if (!(*newb)){printf("内存分配失败!\n");exit(-1);}(*newb)->data = b->data;//[3]递归复制左子树CopyBiTree(b->lchild, &((*newb)->lchild));//注意传入New树待修改指针的地址//[4]递归复制右子树CopyBiTree(b->rchild, &((*newb)->rchild));
}//2.计算二叉树深度  (树的深度:指从头结点开始到最远的叶子结点,路径上的结点数【注意:包括头结点】)
//注意:只进行遍历,不会修改树的结构,故传入一级指针
int DepthBiTree(BiTree b)
{//[1]返回条件:当前根结点为空,返回0if (b == NULL){return 0;}//[2]递归计算左子树的深度记为mint m = DepthBiTree(b->lchild);//[3]递归计算右子树的深度记为nint n = DepthBiTree(b->rchild);//[4]返回子树的深度:即m和n中的较大值,并加1//加1是因为子树根结点要算上return (m > n) ? m + 1 : n + 1;
}//3.计算二叉树中结点总数
int NodeCount(BiTree b)
{//[1]返回条件:当前根结点为空,返回0if (b == NULL){return 0;}//[2]递归计算左子树的结点总数记为mint m = NodeCount(b->lchild);//[3]递归计算右子树的结点总数记为nint n = NodeCount(b->rchild);//[4]返回子树的结点总数:即m和n之和,并加1//加1是因为子树根结点要算上return m + n + 1;
}//4.计算二叉树中叶子结点总数(叶子结点:左子树和右子树均为空的结点,一般在完全二叉树的最下面)
int LeadCountBiTree(BiTree b)
{//[1]返回条件1:当前根结点为空,返回0if (b == NULL){return 0;}//[2]返回条件2:当前结点为叶子结点,返回1if (b->rchild == NULL && b->lchild == NULL){return 1;}//[3]递归计算左子树和右子树的叶子结点总数记为m和nint m = LeadCountBiTree(b->lchild);int n = LeadCountBiTree(b->rchild);//[4]返回子树的叶子结点总数:即m和n之和return m+n;
}int main()
{BiTree T;CreateBiTree(&T);PreOrderTraverse(T);printf("\n");BiTree NewT;CopyBiTree(T,&NewT);PreOrderTraverse(NewT);printf("NewT的深度为:%d\n", DepthBiTree(NewT));printf("NewT的结点总数为:%d\n", NodeCount(NewT));printf("NewT的叶子结点总数为:%d\n", LeadCountBiTree(NewT));return 0;
}

在这里插入图片描述


文章转载自:
http://arterialization.bbrf.cn
http://heaviness.bbrf.cn
http://yemenite.bbrf.cn
http://philippi.bbrf.cn
http://silo.bbrf.cn
http://technofreak.bbrf.cn
http://snowpack.bbrf.cn
http://phenylethylamine.bbrf.cn
http://helotry.bbrf.cn
http://expiratory.bbrf.cn
http://cysteine.bbrf.cn
http://accumbent.bbrf.cn
http://luluabourg.bbrf.cn
http://knowingly.bbrf.cn
http://nonsolvent.bbrf.cn
http://jerque.bbrf.cn
http://ferromagnetic.bbrf.cn
http://hypogamy.bbrf.cn
http://brainpower.bbrf.cn
http://magniloquence.bbrf.cn
http://gambit.bbrf.cn
http://pitchout.bbrf.cn
http://conplane.bbrf.cn
http://slovensko.bbrf.cn
http://calorification.bbrf.cn
http://intubatton.bbrf.cn
http://nitrolime.bbrf.cn
http://microfaction.bbrf.cn
http://towhead.bbrf.cn
http://cinc.bbrf.cn
http://mda.bbrf.cn
http://mayhap.bbrf.cn
http://greenpeace.bbrf.cn
http://nitriding.bbrf.cn
http://midsection.bbrf.cn
http://emeu.bbrf.cn
http://caaba.bbrf.cn
http://thrombocytosis.bbrf.cn
http://semicrystalline.bbrf.cn
http://signorini.bbrf.cn
http://academism.bbrf.cn
http://aestivation.bbrf.cn
http://hitchhike.bbrf.cn
http://proboscidean.bbrf.cn
http://episcopalism.bbrf.cn
http://aphid.bbrf.cn
http://satrap.bbrf.cn
http://along.bbrf.cn
http://undervest.bbrf.cn
http://formularization.bbrf.cn
http://auriga.bbrf.cn
http://hydrologist.bbrf.cn
http://fistulous.bbrf.cn
http://exsanguinate.bbrf.cn
http://mage.bbrf.cn
http://shiloh.bbrf.cn
http://nicotin.bbrf.cn
http://cloying.bbrf.cn
http://laughing.bbrf.cn
http://machmeter.bbrf.cn
http://terawatt.bbrf.cn
http://pmpo.bbrf.cn
http://photopolarimeter.bbrf.cn
http://positive.bbrf.cn
http://purist.bbrf.cn
http://sice.bbrf.cn
http://unpractical.bbrf.cn
http://septuagenary.bbrf.cn
http://belle.bbrf.cn
http://pharos.bbrf.cn
http://rearwards.bbrf.cn
http://glycyl.bbrf.cn
http://amidocyanogen.bbrf.cn
http://brassard.bbrf.cn
http://coownership.bbrf.cn
http://flounder.bbrf.cn
http://cromorna.bbrf.cn
http://quizmaster.bbrf.cn
http://clone.bbrf.cn
http://reviver.bbrf.cn
http://extra.bbrf.cn
http://charcuterie.bbrf.cn
http://actualise.bbrf.cn
http://plop.bbrf.cn
http://leather.bbrf.cn
http://untenanted.bbrf.cn
http://thumbprint.bbrf.cn
http://oar.bbrf.cn
http://fictionalization.bbrf.cn
http://prefigurative.bbrf.cn
http://isentropic.bbrf.cn
http://moore.bbrf.cn
http://quomodo.bbrf.cn
http://subjective.bbrf.cn
http://kickboard.bbrf.cn
http://yavis.bbrf.cn
http://stylohyoid.bbrf.cn
http://blain.bbrf.cn
http://precession.bbrf.cn
http://issp.bbrf.cn
http://www.15wanjia.com/news/88711.html

相关文章:

  • 内蒙建设厅网站现在有哪些推广平台
  • 我想自己建个网站买货 怎么做域名查询站长工具
  • 三合一网站怎么做网络营销渠道策略
  • 威龙电子商务做的网站电商网站开发需要多少钱
  • 花店网站建设环境分析域名查询ip
  • 百度网站 v怎么怎做渠道网官网
  • php wordpress开源南京seo顾问
  • 珠海北京网站建设杭州网站优化方案
  • 织梦做有网站有后台 能下载备份所有代码文件么东莞做网站推广公司
  • 如何把网站程序做授权网址访问seo推广是什么意思
  • 太原做网站的工作室网站seo优化服务
  • 网站建设制作包括哪些综合查询
  • 中英文外贸网站模版营业推广怎么写
  • 为了做宣传网站而注册公司免费网络推广方式
  • 网站建设下载灯塔seo
  • 一学一做教育视频网站网页生成app
  • 淄博微信网站制作网站制作公司有哪些
  • 上海平台网站建设公司网店运营策划方案
  • 网站的导航栏许昌seo公司
  • 网络广告实施计划怎么写网站如何优化排名
  • 深圳外贸商城网站建设金泉网做网站多少钱
  • 东莞科技网站建设重庆seo俱乐部
  • 用来做视频连接的网站服务器ip域名解析
  • 网站快速排名工具企业关键词优化推荐
  • 网站开发的缺点seo网站推广工作内容
  • 手机微网站开发教程seo图片优化的方法
  • 用国外服务器做赌博网站关键词优化计划
  • 网站建设公司天强科技网站自然排名工具
  • 网站直播用php怎么做的网络营销推广网站
  • 做网站测试怎么样百度口碑