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

对网站建设功能的情况说明seo优化技术厂家

对网站建设功能的情况说明,seo优化技术厂家,用jsp做的网站的代码,保定网站制作方案目录 前言: 二叉树的概念与结构 二叉树的链式存储 二叉树的创建 二叉树的销毁 二叉树结点个数计算 二叉树叶子结点个数计算 二叉树第k层节点个数的计算 二叉树高度的计算 二叉树查找值为x的结点 二叉树的遍历 二叉树的前序遍历 二叉树的中序遍历 二叉树…

目录

前言:

二叉树的概念与结构

二叉树的链式存储

 二叉树的创建

二叉树的销毁

二叉树结点个数计算

二叉树叶子结点个数计算

二叉树第k层节点个数的计算

二叉树高度的计算

二叉树查找值为x的结点

 二叉树的遍历

二叉树的前序遍历

二叉树的中序遍历

二叉树的后序遍历

二叉树的层序遍历

判断二叉树是否为完全二叉树


前言:

二叉树的层序遍历需要使用队列实现,队列的实现见数据结构之队列,对于二叉树的代码,需要不断画递归展开图进行结合理解,递归展开图不展开描述;

二叉树的概念与结构

一棵二叉树是n个有限结点的集合,该集合或者为空,或者由一个称为根(root)的结点或者由一个根结点加上两棵别称为左子树和右子树的二叉树组成 ;

二叉树的链式存储

二叉树的链式存储结构指的是用链表表示一棵二叉树,即用链表指示元素的逻辑关系;

通常的方法是链表中每个结点由三个域组成,数据域与左右指针域,左右指针分别用来给出该结点左孩子和右孩子所在的链结点的存储地址;

 二叉树的创建

扩展二叉树是指在二叉树中出现空子树的位置增加空树叶,所形成的二叉树,使得子树成为满二叉树的二叉树叫做扩展二叉树;

先序遍历字符串 A B C # # # D # # 其中“#”表示的是空格,空格字符代表空树,则建立起来的二叉树如下图所示:

//二叉树结点结构
typedef int BTDataType;
typedef struct BinaryTreeNode
{struct BinaryTreeNode* left;struct BinaryTreeNode* right;BTDataType val;
}BTNode;
//创建二叉树,返回根结点地址
//A B C # # # D # #
BTNode* CreateTree(char* str, int* pi)
{if (str[*pi] == '#'){(*pi)++;return NULL;}BTNode* root = (BTNode*)malloc(sizeof(BTNode));root->val = str[*pi];(*pi)++;root->left = CreateTree(str, pi);root->right = CreateTree(str, pi);return root;}
int main()
{char arr[100] = { 'A', 'B', 'C', '#', '#', '#', 'D', '#', '#' };int i = 0;BTNode* root = CreateTree(arr, &i);return 0;
}

二叉树的销毁

按照先销毁其左子树,再销毁右子树,最后销毁根的顺序递归销毁二叉树;

void DestroyTree(BTNode* root)
{if (root == NULL)return;DestroyTree(root->left);DestroyTree(root->right);free(root);
}

二叉树结点个数计算

若根结点为空,则二叉树结点个数=0;

若根节点不为空,则二叉树结点个数=左子树的结点个数+右子树极点个数+1;

//二叉树结点个数
int TreeSize(BTNode* root)
{if (root == NULL)return 0;return TreeSize(root->left) + TreeSize(root->right) + 1;
}

二叉树叶子结点个数计算

叶子结点即某一节点出的左孩子为空并且右孩子为空则为叶子结点;

//二叉树叶子结点个数
int TreeLeafSize(BTNode* root)
{if (root == NULL)return 0;if (root->left == NULL && root->right == NULL)return 1;return TreeLeafSize(root->left) + TreeLeafSize(root->right);
}

二叉树第k层节点个数的计算

规定:二叉树的层数K以1为起点,即第一层 k = 1;

二叉树的第k层节点个数=其左子树的第k-1层节点个数+其右子树的第k-1层节点个数;

int TreeKLevel(BTNode* root,int k)
{assert(k > 0);if (root == NULL)return 0;if (k == 1)return 1;return TreeKLevel(root->left, k - 1) + TreeKLevel(root->right, k - 1);
}

二叉树高度的计算

二叉树的高度=左子树的高度与右子树的高度较大值+1;

//二叉树的高度
int TreeHeight(BTNode* root)
{if (root == NULL)return 0;int LeftHeight = TreeHeight(root->left);int RightHeight = TreeHeight(root->right);return LeftHeight > RightHeight ? LeftHeight + 1 : RightHeight + 1;
}

二叉树查找值为x的结点

如根节点非空,先查找根,如果根结点处的值即为查找的值,直接返回根节点的地址,如果根节点处未查找到,先查找左子树,找到了直接返回,找不到继续查找右子树;

//二叉树查找值为x的结点
BTNode* TreeFind(BTNode* root, BTDataType x)
{if (root == NULL)return NULL;if (root->val == x)return root;struct BinaryTreeNode* ret = NULL;ret = TreeFind(root->left, x);if (ret != NULL)return ret;ret = TreeFind(root->right, x);if (ret != NULL)return ret;return NULL;
}

 二叉树的遍历

  • 前序遍历NLR(依次遍历:根结点—左子树—右子树)
  • 中序遍历LNR(依次遍历:左子树—根结点—右子树)
  • 后序遍历LRN(依次遍历:左子树—右子树—根结点)

 由于二叉树是递归定义的,按照下图所示方法,便可得到前序遍历的结点顺序

 前序遍历结果:A->B->D->E->C->F->G        

中序遍历结果为D->B->E->A->F->C->G;后序遍历结果:D->E->B->F->G->C->A;

二叉树的前序遍历

//二叉树的前序遍历
void PrevOrder(BTNode* root)
{if (root == NULL)return;printf("%c ", root->val);PrevOrder(root->left);PrevOrder(root->right);
}

二叉树的中序遍历

//二叉树的中序遍历
void InOrder(BTNode* root)
{if (root == NULL)return;InOrder(root->left);printf("%c ", root->val);InOrder(root->right);
}

二叉树的后序遍历

//二叉树的后序遍历
void PostOrder(BTNode* root)
{if (root == NULL)return;PostOrder(root->left);PostOrder(root->right);printf("%c ", root->val);
}

二叉树的层序遍历

二叉树的层序遍历是指将二叉树从上到下,从左到右依次遍历,如下图所示层序遍历结果为

A—>B—>D—>C

层序遍历的思路如下:

1.  判断根结点是否为空,非空则入队列

2. 判断队列是否为空,不为空则队头元素出队列,再将队头元素的孩子入队列,若队头元素的孩子为空,则不入队列;

3.判断队列是否为空,将B出队列,再将B的孩子入队列;

4.判断队列是否为空,将D出队列,再将D的孩子入队列;

5. 判断队列是否为空,将C出队列,再将C的孩子入队列;队列为空时结束遍历;

//二叉树的层序遍历
void BinaryTreeLevelOrder(BTNode* root)
{Queue q;InitQueue(&q);if (root != NULL)QueuePush(&q, root);while (!QueueEmpty(&q)){BTNode* front = QueueFront(&q);printf("%c ", front->val);if (front->left != NULL);QueuePush(&q, front->left);if (front->right != NULL)QueuePush(&q, front->right);QueuePop(&q);}DestroyQueue(&q);
}

判断二叉树是否为完全二叉树

满二叉树:当二叉树深度为K,二叉树结点个数为2^k-1,则为满二叉树;

对满二叉树结点位置进行编号

  • 编号的规则:自上而下,从左向右 ;
  • 每一节点位置都有元素;

完全二叉树

深度为K具有n个结点的二叉树,当且仅当其每一个节点都与深度为k的满二叉树中的编号为1~n的节点一 一对应时,称为完全二叉树;

判断二叉树是否是完全二叉树,是完全二叉树返回true,否则返回false;
利用二叉树层序遍历,非空结点连续为完全二叉树,非空结点不连续,存在空节点,则为非完全二叉树;

int BinaryTreeComplete(BTNode* root)
{Queue q;InitQueue(&q);if (root != NULL)QueuePush(&q, root);while (!QueueEmpty(&q)){BTNode* front = QueueFront(&q);if (front == NULL)break;QueuePush(&q, front->left);QueuePush(&q, front->right);QueuePop(&q);}//若已经出现空结点,队列后面结点存在非空结点,则为非完全二叉树while (!QueueEmpty(&q)){BTNode* front = QueueFront(&q);QueuePop(&q);if (front != NULL){DestroyQueue(&q);return false;}}DestroyQueue(&q);return true;
}

http://www.hkea.cn/news/885286/

相关文章:

  • cuntlove wordpressseo外链发布工具
  • 购买一个网站空间如何可以多个域名使用吗长沙网站建设服务
  • 天津市建设委员会网站上海网站制作开发
  • 扬中网站建设墨子学院seo
  • 分析电子商务网站建设需求教案青岛今天发生的重大新闻
  • 汕头模板开发建站百度发布信息怎么弄
  • 健身网站开发项目总结关键词筛选工具
  • 重庆网站建设零臻靠谱国内永久免费的云服务器
  • 软件库合集软件资料2024郑州百度快照优化
  • 房地产开发公司网站建设方案seo去哪里学
  • 做网站可以赚钱吗百度小说搜索风云排行榜
  • 做网站交接需要哪些权限网站seo视频教程
  • 在网站怎么做收款二维码刷移动关键词优化
  • 问信息奥赛题怎么做 去哪个网站互联网网络推广
  • b2c电子商务网站系统下载专业网站seo推广
  • 引流推广的方法seo诊断工具
  • 平阴县建设工程网站直通车推广怎么做
  • 网站开发外包不给ftp高佣金app软件推广平台
  • 太原适合网站设计地址百度用户服务中心客服电话
  • 济南源码网站建设长沙网站seo推广公司
  • 北京网站制作17页和业务多一样的平台
  • 无锡市住房城乡建设委网站简单网页设计模板html
  • 武汉市大型的网站制作公司网站ip查询
  • 做仪表行业推广有哪些网站电商网站设计
  • 动静分离网站架构百度售后客服电话24小时
  • 做汽车配件生意的网站佛山seo关键词排名
  • 创意建站推荐百度做广告多少钱一天
  • 巴中网站建设公司百度seo怎么做网站内容优化
  • 查网站备案名称上海网络营销seo
  • 人是用什么做的视频网站网络营销方案设计毕业设计