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

怎么做算命网站wordpress pkm

怎么做算命网站,wordpress pkm,wordpress 百度不收录,哪个网站做签约设计师比较好一.什么是树: 树形结构是一层次的嵌套结构。一个树形结构的外层和内层有相似的结构,所以这种结构多可以递归的表示。经典数据结构中的各种树状图是一种典型的树形结构:一棵树可以简单的表示为根,左子树,右子树。左子树…

一.什么是树:

树形结构是一层次的嵌套结构。一个树形结构的外层和内层有相似的结构,所以这种结构多可以递归的表示。经典数据结构中的各种树状图是一种典型的树形结构:一棵树可以简单的表示为根,左子树,右子树。左子树和右子树又有自己的子树。

 树的一些属性:

1、结点(Node):表示树中的数据元素,由数据项和数据元素之间的关系组成。在图中,共有10个结点。

2、结点的度(Degree of Node):结点所拥有的子树的个数,在图中,结点A的度为3。

3、树的度(Degree of Tree):树中各结点度的最大值。在图5.1中,树的度为3。

4、叶子结点(Leaf Node):度为0的结点,也叫终端结点。在图5.1中,结点E、F、G、H、I、J都是叶子结点。

5、分支结点(Branch Node):度不为0的结点,也叫非终端结点或内部结点。在图5.1中,结点A、B、C、D是分支结点。

6、孩子(Child):结点子树的根。在图中,结点B、C、D是结点A的孩子。

7、双亲(Parent):结点的上层结点叫该结点的双亲。在图中,结点B、C、D的双亲是结点A。

8、祖先(Ancestor):从根到该结点所经分支上的所有结点。在图中,结点E的祖先是A和B。

9、子孙(Descendant):以某结点为根的子树中的任一结点。在图中,除A之外的所有结点都是A的子孙。

10、兄弟(Brother):同一双亲的孩子。在图5.1中,结点B、C、D互为兄弟。

11、结点的层次(Level of Node):从根结点到树中某结点所经路径上的分支数称为该结点的层次。根结点的层次规定为1,其余结点的层次等于其双亲结点的层次加1。 [1]

12、堂兄弟(Sibling):同一层的双亲不同的结点。在图中,G和H互为堂兄弟。

13、树的深度(Depth of Tree):树中结点的最大层次数。在图5.1中,树的深度为3。 [1]

14、无序树(Unordered Tree):树中任意一个结点的各孩子结点之间的次序构成无关紧要的树。通常树指无序树。 [1]

15、有序树(Ordered Tree):树中任意一个结点的各孩子结点有严格排列次序的树。二叉树是有序树,因为二叉树中每个孩子结点都确切定义为是该结点的左孩子结点还是右孩子结点。 [1]

16、森林(Forest):m(m≥0)棵树的集合。自然界中的树和森林的概念差别很大,但在数据结构中树和森林的概念差别很小。从定义可知,一棵树由根结点和m个子树构成,若把树的根结点删除,则树变成了包含m棵树的森林。当然,根据定义,一棵树也可以称为森林。

一些特殊的树:

树中最特殊最经典的就是二叉树,二叉树顾名思义就是只有两个分叉的树,也就是度为二的树。

二叉树中又有俩个最为经典的树分别为完全二叉树和满二叉树。

一棵深度为k且有个结点的二叉树称为满二叉树。

如果对满二叉树的结点进行编号, 约定编号从根结点起, 自上而下, 自左而右。则深度为k的, 有n个结点的二叉树, 当且仅当其每一个结点都与深度为k的满二叉树中编号从1至n的结点一一对应时, 称之为完全二叉树。

二.用c语言实现一颗树:

要实现一颗树我们首先要先定义一个树的结构体

然后要确定我们树的基本功能

 

接着就是写完这些函数

 

#include"BinaryTree.h"BTNode* BinaryTreeCreate(BTDataType* a, int* pi)
{if (a[*pi] == '#'){(*pi)++;return NULL;}BTNode* root = (BTNode*)malloc(sizeof(BTNode));root->data = a[(*pi)++];root->left = BinaryTreeCreate(a, pi);root->right = BinaryTreeCreate(a, pi);return root;
}void BinaryTreeDestory(BTNode* root)
{assert(root);if (root == NULL)return;BinaryTreeDestory(root->right);BinaryTreeDestory(root->left);free(root);root = NULL;
}int BinaryTreeSize(BTNode* root)
{if (root == NULL)return 0;return BinaryTreeSize(root->left) + BinaryTreeSize(root->right) + 1;
}int BinaryTreeLeafSize(BTNode* root)
{if (root == NULL)return 0;if (root->left == NULL && root->right == NULL)return 1;return BinaryTreeLeafSize(root->left) + BinaryTreeLeafSize(root->right);
}int BinaryTreeLevelKSize(BTNode* root, int k)
{if (root == NULL)return 0;if (k == 1)return 1;k--;return BinaryTreeLevelKSize(root->left,k) + BinaryTreeLevelKSize(root->right,k);
}BTNode* BinaryTreeFind(BTNode* root, BTDataType x)
{if (root == NULL)return NULL;if (root->data == x)return root;BTNode* leftfind = BinaryTreeFind(root->left, x);if (leftfind != NULL)return leftfind;BTNode* rightfind = BinaryTreeFind(root->right, x);if (rightfind != NULL)return rightfind;return NULL;
}void BinaryTreePrevOrder(BTNode* root)
{if (root){printf("%c", root->data);BinaryTreePrevOrder(root->left);BinaryTreePrevOrder(root->right);}
}void BinaryTreeInOrder(BTNode* root)
{if (root){BinaryTreeInOrder(root->left);printf("%c", root->data);BinaryTreeInOrder(root->right); }
}void BinaryTreePostOrder(BTNode* root)
{if (root){BinaryTreePostOrder(root->left);BinaryTreePostOrder(root->right);printf("%c", root->data);}
}

http://www.yayakq.cn/news/880498/

相关文章:

  • 网站建设费怎么做分录网站登录页面制作
  • 北京 科技网站建设wordpress粘帖图片
  • 四川省住房和城镇建设官方网站原始传奇经典复古
  • 备案网站ip群辉服务器建设的网站
  • 网站规划分析的好处wordpress 自动相册
  • 云集网站建设公司室内装修设计上海
  • 上海网站建设开发公司哪家好个人网站方案建设书
  • 可以做四级的网站东莞专业建站公司费用
  • Wordpress建站安装教程图解设计公司资质申请
  • wordpress模板修改服务关键词优化公司如何选择
  • 虚拟主机WordPress建站wordpress sae 插件
  • 汕头免费自助建站模板外贸网站建设商家
  • 新手做网站做什么样的简述网络营销的概念
  • 网站开发语言为h5页面可以跳转到小程序吗
  • 网站建设数据收集方法icp备案查询官方网站
  • wordpress设计的网站西安网红
  • 彩票网站搭建多钱江西城乡建设厅网站
  • 手机网站 微信网站 区别免费的郑州网络推广服务
  • 怎么做电脑端网站设计稿qq网页版一键登录
  • 八亿wap建站石家庄便宜网站制作
  • 网站权重网站建设 宁夏
  • 深圳极速网站建设定制html登录页面制作
  • 网站首页包含的内容怎么做网站备案是否收费
  • 网站404页面下载营销型网站定制
  • 毕业设计报告网站开发学软件去哪个培训机构
  • 做建材网站wordpress注册中文
  • 山西众邦建设集团网站如何制造一个网站
  • 百度免费推广网站网页设计欣赏怎么写
  • 智能网站价格桓台新城建设有限公司网站
  • 网站建设属于什么资产给自己做的网站换首页