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

门户定制网站建设公司微信小程序开发网站建设

门户定制网站建设公司,微信小程序开发网站建设,网站分布,个人网站放什么内容目录 二叉树 特点 性质 二叉树的创建 声明 创建 - 成员运算符 批量创建 二叉树的遍历 先序遍历 中序遍历 后序遍历 层序遍历 树的相关术语 特殊二叉树 满二叉树 完全二叉树 二叉树 树#xff08;Tree#xff09;是n(n≥0)个节点的有限集。在任意一棵… 目录 二叉树  特点 性质 二叉树的创建 声明 创建 - 成员运算符 批量创建 二叉树的遍历 先序遍历 中序遍历 后序遍历 层序遍历 树的相关术语 特殊二叉树 满二叉树 完全二叉树 二叉树  树Tree是n(n≥0)个节点的有限集。在任意一棵树中有且仅有一个特定的称为根Root的节点当n1时其余节点可分m(m0)为个互不相交的有限集T1,T2,...,Tm其中每一个集合本身又是一棵树并且称为根的子树SubTree。 二叉树Binary Tree是一种特殊的有序树型结构所有节点最多只有2棵子树。 特点 1每个节点至多有两棵子树 2二叉树的子树有左右之分 3子树的次序不能任意颠倒有序树。 性质 1二叉树的第i层上至多有2^(i-1)个节点i≥1。 2深度为h的二叉树中至多含有2^h-1个节点(h≥1)。 3若在任意一棵二叉树中有n0个叶子节点有n2个度为2的节点则必有n0n21。 4具有n个节点的满二叉树深为log2n1。 5若对一棵有n个节点的完全二叉树进行顺序编号1≤i≤n 那么对于编号为ii≥1的节点    当i1时该节点为根它无双亲节点。   当i1时该节点的双亲节点的编号为i/2。   若2i≤n则有编号为2i的左节点否则没有左节点。   若2i1≤n则有编号为2i1的右节点否则没有右节点。 二叉树的创建 声明 struct TreeNode {int val;TreeNode* left;TreeNode* right;TreeNode(int x) : val(x), left(NULL), right(NULL) {} }; 在C/C语言中经常使用 NULL 来表示空指针。 NULL在头文件里的定义 #ifndef NULL#ifdef __cplusplus#define NULL 0#else#define NULL ((void *)0)#endif #endif 即在 C中NULL 被定义为整形常量 0而在 C 中被定义为无类型指针常量 (void*) 0 。 C11标准增加了新的关键字 nullptr表示空指针。 建议使用C11及以上版本的用以下的二叉树声明 struct TreeNode {int val;TreeNode* left;TreeNode* right;TreeNode(int x) : val(x), left(nullptr), right(nullptr) {} }; 创建 #include iostreamstruct TreeNode {int val;TreeNode* left;TreeNode* right;TreeNode(int x) : val(x), left(nullptr), right(nullptr) {} };int main() {TreeNode* root new TreeNode(1);root-left new TreeNode(2);root-right new TreeNode(3);root-right-left new TreeNode(4);root-right-right new TreeNode(5);return 0; } 创建结果 成员运算符- 指向结构体或对象的指针访问其内成员。当一个指针指向一个结构体、对象时称之为结构体指针或对象指针。结构体指针或对象指针中的值是所指向的结构体或对象的首地址。通过结构体指针或对象指针即可访问该结构体或对象。 结构体指针变量定义的一般形式为 struct 结构体类型名 *指针名; //结构体指针 struct 结构体类型名 *指针名 一个结构体的名字; //结构体指针并赋初值 struct 结构体类型名 *指针名 new struct 结构体类型名; //结构体指针并用new申请内存 struct 结构体类型名 *指针名 (struct 结构体类型名 *)malloc(sizeof(struct 结构体类型名)) //结构体指针并用malloc申请内存 使用应包含头文件stdlib.h 子树root-left, root-right 还可以 . 运算表示也成员运算符。两者的区别 点运算符 . 左边必须用 * 寻址运算符取到指针root指向的结构或者对象实体如(*root)对比箭头状的成员运算符 - 其左边必须为结构体指针如root。 TreeNode* root new TreeNode(1);(*root).left new TreeNode(2);(*root).right new TreeNode(3);(*(*root).right).left new TreeNode(4);(*(*root).right).right new TreeNode(5); 批量创建 上例只是创建5节点如要建更多节点这样一个一个增加节点写起来复杂可以用数组或容器等可迭代数据类型批量来创建。 代码明天补上 二叉树的遍历 指如何按某种搜索路径巡防树中的每个结点使得每个结点均被访问一次而且仅被访问一次。 常见的遍历方法有先序遍历中序遍历后序遍历层序遍历。 以一棵满二叉树为例 _______1________/ \__2__ ___3___/ \ / \4 5 _6 _7/ \ / \ / \ / \ 8 9 10 11 12 13 14 15 先序遍历 若二叉树为空为空操作 否则1访问根节点2先序遍历左子树3先序遍历右子树。 遍历结果 1 [2 [4 8 9] [5 10 11]] [3 [6 12 13] [7 14 15]   “根左右” 中序遍历 若二叉树为空为空操作 否则1中序遍历左子树2访问根结点3中序遍历右子树。 遍历结果 [[8 4 9] 2 [10 5 11]] 1 [[12 6 13] 3 [14 7 15]]  “左根右” 后序遍历 若二叉树为空为空操作 否则1后序遍历左子树2后序遍历右子树3访问根结点。 遍历结果 [[8 9 4] [10 11 5] 2] [[12 13 6] [14 15 7] 3] 1  “左右根” 层序遍历 若二叉树为空为空操作否则从上到下、从左到右按层次进行访问。 遍历结果 1 [2 3] [4 5 6 7] [8 9 10 11 12 13 14 15] 代码明天补上 树的相关术语 节点包含一个数据元素及若干指向其子树的分支又的译成“结点”Node根树和子树的“顶点”Root度节点拥有的子树数量称为节点的度Degree树的度是指树内个结点的度的最大值分支节点度不为0的节点叶子没有子树的节点即它的度为0 Leaf子节点结点的子树的根称为该节点的孩子Child父节点对应子节点上一层(level)节点称为该节点的双亲Parent兄弟结点同一父节点的子节点互称兄弟Sibling 节点的祖先是从根到该结点所经分支上的所有节点 节点的子孙以某结点为根的子树中的所有节点层从根开始根为第一层根的孩子为第二层...Level深度树中结点的最大层次数称为树的深度或高度 Depth or Height森林是很多互不相交的树的集合Forest 无序树树中任意节点的子节点之间没有顺序关系这种树称为无序树也称为自由树有序树树中任意节点的子节点之间有顺序关系这种树称为有序树最大树最小树每个结点的值都大于小于或等于其子结点如果有的话值的树 特殊二叉树 满二叉树 所有层的节点都达到最大数量叶子除外的所有节点都有两个子节点所有叶子都在最底一层(k)且数目为2^(k - 1)。即深度k且有2^k - 1个节点(叶子“长”满最后一层)或称完美二叉树 Perfect Binary Tree ______12_______/ \__3__ __5__/ \ / \_7 6 _9 11/ \ / \ / \ / \ 13 8 1 4 10 2 0 14 完全二叉树 如果删除最底一层的所有叶子它就是满二叉树即除了最后一层每层节点都达到最大数量 即有深度k的个节点数在左闭右开【2^(k-1)1,2^k-1】区间内。Complete Binary Tree ________3______/ \___11___ __4__/ \ / \14 7 9 13/ \ / \ / 2 5 8 6 1 完全二叉树性质 1. 具有N个节点的完全二叉树的深度为[log2 N]1其中[x]为高斯函数截尾取整。 2. 如果对一棵有n个节点的完全二叉树的节点按层序编号从第一层到最后一层每层从左到右则对任一节点有 1如果i1则节点i是二叉树的根无双亲如果i1,则其双亲节点为[i/2] 2如果2in则节点i无左孩子否则其左孩子是节点2i 3如果2i1n则节点i无右孩子否则其右孩子是节点2i1。
http://www.hkea.cn/news/14319079/

相关文章:

  • mvc网站入口asp东网站建设
  • 东营市垦利区胜坨填建设站的网站全国知名网站建设
  • 个人网站免费模板下载wordpress中文二次元
  • 如何增加新网站的百度收录国家级建设网站
  • 免费成品网站下载商城平台系统
  • 网站在建设是什么意思网络营销优化推广公司
  • 个人可以做网站导航模板网站劣势
  • 网站后台根据前端做吗网站怎么做网站地图
  • 网站死链对网站影响淘宝客高佣金网站建设
  • 深圳做网站的给说沈阳网站建设哪家做得好
  • 智能锁东莞网站建设一个官网
  • 河南网站建设yijuce标智客在线logo设计生成器免费
  • 网页设计与网站建设的课后习题答案网站分析的数据来源有哪些
  • 玉树市wap网站建设公司凡诺企业网站管理系统
  • 响应式网站的建设东营优化路网
  • 北京手机网站广告招商
  • 励志网站织梦源码东莞清溪网站制作
  • 俄文网站商城建设加强网站信息内容建设管理
  • 宣城高端网站建设猪八戒托管赏金做网站
  • 做外贸网站用哪些小语种网站空间如何使用
  • 网络网站知识app手机网站建设图片
  • 吴川网站建设重庆网站建设制作
  • 小域名 网站备案做内部网站费用
  • 网站建设千套素材制作一个网站并上传访问
  • 给别人做网站需要增值电信做html的简单网站
  • 四川成都网站网页设计wordpress升级无法创建目录
  • 外贸网站高端定做广东建设项目备案公示网站
  • 深圳企业网站建设服务中心wordpress 国内 主题
  • 网站可以不备案石家庄网络关键词排名
  • 做网站分什么酒店移动网站建设方案