栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

从其预购和后购清单重建树

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

从其预购和后购清单重建树

您不能只使用一个列表,因为您将无法理解树的深度。因此,您肯定需要两个或多个列表。

这是我尝试的解决方案:

使用预遍历作为了解数据顺序的一种方法。这是有道理的,因为您知道第一个节点是顶部,并且知道遍历左侧的数据属于树的左侧,依此类推。

您的订单遍历可以确定树的深度。例如,假设我有一个这样的结构:

      1  2   5   6 3 4  7Where 2 is the parent of 3 and 4, and 5 is the parent of 7.Preorder: 1 2 3 4 5 7 6Postorder: 3 4 2 7 5 6 1

我们知道我们从1开始,因为它是预遍历中的第一个节点。然后我们看下一个数字2,在后顺序中,因为数字2出现在节点1之前,所以我们知道2必须是1的子代。接下来看3。3出现在2之前,因此3是2的孩子。4在2之前但在3之后,因此我们知道4是2的孩子,但不是3的孩子。

现在,如果节点不是唯一的,则这可能不起作用,但至少是解决方案的开始。

编辑: 使用此解决方案可以保留子项的顺序,这仅是由于通过预顺序遍历了解节点的顺序,然后通过后顺序遍历了解结构。

Edit2:
证据可能在这里:http
**//ieeexplore.ieee.org/Xplore/login.jsp?url = http%

**3A%2F%2Fieeexplore.ieee.org%2Fiel2%2F215%2F626%2F00017225.pdf%3Farnumber%

3D17225&authDecision =
-203

我认为您需要购买该文档,但是…

以下是作为解决方案的书面证明:

http://www14.informatik.tu-muenchen.de/lehre/2007WS/fa-
cse/tutorials/tutorial09-solutions.pdf



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/660507.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号