求教,树转二叉树,如图

作者&投稿:采郎 (若有异议请与网页底部的电邮联系)
将下图所示的树转化成二叉树。~


如图


A的第一个孩子B为左子树,B的兄弟为右子树,B的孩子为左子树。按照这个规律,可以得到E的兄弟为右子树,D的孩子为左子树。应该就是这样了吧

分为三个步骤:兄弟+横线 树中的每一个结点,如果该结点有兄弟结点,那么就在这几个兄弟结点之间进行连线。保存长子线 对于树中的每一个结点,如果其有多个子节点,保存其第一个子节点的连线,去除其他子节点的连线。调整位置 对每个结点调整一定的位置,使其符合二叉树的标准。




...下g第三棵树h下ij,i下k,求把上述森林转化成二叉树,谢谢
森林是这样的:转换成的二叉树是这样的:

什么是森林,树转换为二叉树有什么意义?
排序、搜索、查找的效率都很高。树转换为二叉树是遵循一定规律的:按由左向右的次序,根节点的第一个子节点成为新的二叉树该节点的左子节点,其他节点调整为前一节点的右子节点,即右子节点在原来树是其父节点的兄弟节点。关于这方面推荐你搜一下相关的博客博文,图文并茂更容易理解。

求数据结构树与二叉树转换C语言代码
(2)链表存储方式,如:type btree=^node;node=record data:datatye;lchild,rchild:btree;end;5.普通树转换成二叉树:凡是兄弟就用线连起来,然后去掉父亲到儿子的连线,只留下父母到其第一个子女的连线。二叉树很象一株倒悬着的树,从树根到大分枝、小分枝、直到叶子把数据联系起来,这种数据结构...

如果T2是由树T1转换而来的二叉树,那么T1中结点的先序就是T2中结点的...
树的先序序列与对应的二叉树的先序序列一样的。这个可以随便画一棵树,然后转换成对应的二叉树,分别对它们作先序遍历就可以得到答案是A

把一棵树转换为二叉树后,这棵树的形态是唯一的吗
应该问的是这棵二叉树形态是唯一的吧,这个只要转换规则一致,结果自然唯一

树与二叉树的转换的实现。以及树的前序、后序的递归、非递归遍历算法...
\/\/层次遍历代码 template<class T> void BinTree<T>::view(){ if (IsNull()) return;deque<TreeNode<T>*> q;TreeNode<T>* temp;q.push_back(root);while(!q.empty()){ temp = q.front();q.pop_front();cout<<temp->data;if (temp->Left!=NULL)q.push_back(temp->Left);if...

数据结构树转换为二叉树时,树有分左右子树吗???
树也分,左边的是第一个孩子,其他的各个孩子顺次接在结点的右子树

将森林转化为二叉树得到二叉树正好是一个满二叉树罗曼二叉树中有n个...
C.n+1 森林转换为二叉树,遵循"左儿子右兄弟"的说法.举个例子.树:根节点有三个儿子A,B,C.那么转换为二叉树后,根节点只有一个儿子A,然后A的兄弟B成为A的"儿子"(或者可以说是右指针域),C成为B的右指针域,此时C已经没有兄弟了,所以到此的一个右指针域为空.(你可以画图体会一下.)题目中说F...

请教树转为二叉树的C++算法
不久是波兰编码么?我不了解你这样做想干嘛?加478057708,给你个代码看看,何必这么麻烦,直接利用堆栈写个二叉树不是更简单?

数据结构 设一棵树T中边的集合为{(A,B),(A,C),(A,D),(B,E),(C,
1、画出该树 :如下图左边所示。然后根据树的二叉链表表示法表示存储结构如图右边所示:注意这里的指针域为左边表示第一个孩子*firstchild,右边表示兄弟*nextsibling 2、接着进行树与二叉树的转换就可以得到结果了,核心思想:左子树放孩子,右子树放兄弟,则有如图所示的二叉树:...

吉安市17247821623: 树转换为二叉树 -
蒸元喉症: 将树中相邻的兄弟连起来,并保留每个结点的第一个子树,删掉与其他子树的连线,调整位置.大概就是这个样子 数据结构刚开始学 好烦

吉安市17247821623: 树怎么转化为二叉树 -
蒸元喉症: 1、去除所有父结点也孩子结点连线; 2、把父结点与最左边的孩子相连,作为父结点的左孩子; 3、把同层结点的兄弟结点相连作为左边兄弟的右孩子; 以此类推所有结点即得到二叉树.

吉安市17247821623: 这样的树怎么转换成二叉树? -
蒸元喉症: 左子树是第一个孩子,右子树是其第一个兄弟(sibling),递归定义.

吉安市17247821623: 数据结构的树和二叉树之间怎么转换? -
蒸元喉症: 将树转换成二叉树:① 加线:在兄弟之间加一连线 ② 抹线:对每个结点,除了其左孩子外,去除其与其余孩子之间的关系 ③ 旋转:以树的根结点为轴心,将整树顺时针转45° 将二叉树转换成树:① 加线:若p结点是双亲结点的左孩子,则将p的右孩子,右孩子的右孩子……沿分支找到的所有右孩子,都与p的双亲用线连起来 ② 抹线:抹掉原二叉树中双亲与右孩子之间的连线 ③ 调整:将结点按层次排列,形成树结构

吉安市17247821623: 将一棵三叉树转换成二叉树 -
蒸元喉症: 第一步:将拥有同一个父亲的所有兄弟结点连起来,第二步:如果一个父亲拥有n(n=2或者3)个孩子,将他最右边的n-1个孩子删掉.第三步:这时已经是一颗二叉树,调整一下空间位置即可,不过要注意结点是左结点还是右结点(从图中就能看出来).

吉安市17247821623: 森林与二叉树的转换
蒸元喉症: 树、森林与二叉树的转换 1、 树、森林转换成二叉树 将一棵树转换成二叉树的方法: 将一棵树转换成二叉树实际上就是将这棵树用孩子兄弟表示法存储即可,此时,树中的每个结点最多有两个指针:一个指针指向第一个孩子,另一个指针指向...

吉安市17247821623: 数据结构与算法中 树转为二叉树 需要什么准则和要求吗??
蒸元喉症: 根据树与二叉树的转换方法:将树的所有左子树与根的连接保留,将其余的连接断掉,而把子树层的所有兄弟相连作为其左子树的右子树.递归下去就行了.见数据结构(C语言版)P137

吉安市17247821623: 请将下图转换成二叉树!
蒸元喉症: 方法是:把每个结点的所有孩子用直接连接起来,然后断开除了左孩子之外的其他孩子的关系.再以树根结点为轴心,装树顺时针转45度.最后得到:

吉安市17247821623: 1.对如下图所示的树,(1)写出其前根遍历序列和后根遍历序列,(2)将其转换为二叉树. -
蒸元喉症: 1.前根:ABEFHIJCDG 后根:EHIJFBCGDA2.WPL=(1+2)*5 + 5*4 +7*3 + 16*2 + 20*1 = 108

吉安市17247821623: c语言如何将树转成二叉树,并对其进行非递归遍历? -
蒸元喉症: 树转二叉树,只要将首子节点当做左节点,兄弟节点当做右节点即可 非递归遍历的话,则对节点需要构造一个next的指针,构造的时候深度优先探索,生成先序序列的next链

本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 星空见康网