文档章节

预排序遍历树算法(modified preorder tree traversal algorith

mac_zhao
 mac_zhao
发布于 2015/06/25 11:22
字数 645
阅读 397
收藏 5
这个算法有如下几个数据结构:
1、lft 代表左 left
2、rgt 代表右 right
3、lvl 代表所在的层次 level
下面这个图是一个典型的结构:

 

 我们先看一些使用方法

1、查看整个树(A)有多少节点(包含自己),直接看根节点就行了 (right-left+1)/2 = (20-1+1)/2 = 10

   这个数有10个节点

2、查看从节点A到E的路径

   1 select * from tree where lft between 1 and 6 and rgt between 7 and 20 order by lft

 

  得到的结果是A,B,D,E 这4个节点的数据,且按照访问路径的顺序

  如果2个节点之间不是上下级的关系,则查询没有结果

  反向也是一样的,可以拿到底部一个节点,到上级节点的路径

  1 select * from tree where lft between 1 and 6 and rgt between 7 and 20 order by lft desc

 

  唯一的区别就是排序是反向的就行了。

3、得到某个节点下面的所有节点,且按照树状结构返回我们用B做例子

  1 select * from tree where lft>2 and right<11 order by lft

 

  拿到的结果是 C,D,E,F,而且顺序也是正确的。

4、拿到所有下2级的子节点我们A做例子,这次加上了lvl的参数,因为A的level是1,所以我们查询level不大于3的。

  1 select * from tree where lft>2 and right<11 and lvl<=3 order by lft

 

  下面看我们新增加一个节点的方法。我们在根节点的下面,G节点的右侧增加一个X节点

 

我们要做的工作就是

1、G节点的右参数为13

2、变更所有的受影响的节点,给新节点腾出空位子,所有左节点比G节点大的,都增加2

   1 update tree set lft=lft+2 where lft>12

 

   所有右节点比G节点大的,都增加2

  1 update tree set rgt=rgt+2 where rgt>13

 

3、新节点放在空位子上,lft=14,rgt=15,这样就完成了一个新节点的增加操作。

算法说明:

1.所有分类 左边和右边的值 > 插入节点的左边节点记录的右值 的全部 + 2

2.插入节点 左值 = 插入位置左边节点记录的右值 + 1, 右值 = 插入位置左边节点记录的右值 + 2

  

 其它相关说明请参考:

 http://be-evil.org/tb.php?sc=67fcc&id=168

  http://blog.csdn.net/wisewillpower/archive/2008/04/19/2306461.aspx

© 著作权归作者所有

共有 人打赏支持
mac_zhao
粉丝 42
博文 249
码字总数 304671
作品 0
普陀
程序员
私信 提问
树状分类结构,数据库构建(预排序历遍算法)

树状结构的数据保存在数据库中的常用方法有一下两种: 1、邻接表(adjacency list model) 2、预排序遍历树算法(modified preorder tree traversal algorithm) 用一下的例子讨论这两种方法的差...

liangyx
2013/01/02
0
6
PHP+Mysql树型结构(无限分类)数据库设计的2种方式实例

我们经常需要在关系型数据库中保存一些树状结构数据,比如分类、菜单、论坛帖子树状回复等。常用的方法有两种: 1. 领接表的方式; 2. 预排序遍历树方式; 假设树状结构如下图: 领接表方式 ...

我心中有猛狗
2016/10/29
43
0
HDU 1710 Binary Tree Traversals

Binary Tree Traversals   A binary tree is a finite set of vertices that is either empty or consists of a root r and two disjoint binary trees called the left and right subtre......

suvvm
11/04
0
0
如何用数据库保存多级结构的数据

产品分类,多级的树状结构的论坛,邮件列表等许多地方我们都会遇到这样的问题:如何存储多级结构的数据?在PHP的应用中,提供后台数据存储的通常是关系型数据库,它能够保存大量的数据,提供...

xiao刀
2015/10/17
124
0
Leetcode 二叉树解题报告

1. Binary Tree Preorder Traversal Description Given a binary tree, return the preorder traversal of its nodes' values. Example: Input: [1,null,2,3] 1 2 / 3 Output: [1,2,3] Analy......

BookThief
07/29
0
0

没有更多内容

加载失败,请刷新页面

加载更多

Maven 依赖范围(Dependency Scope)

Dependency Scope Dependency scope is used to limit the transitivity of a dependency, and also to affect the classpath used for various build tasks. 依赖范围用于限制依赖项的传递性......

晨猫
18分钟前
1
0
细述hbase协处理器

1.起因(Why HBase Coprocessor) HBase作为列族数据库最经常被人诟病的特性包括:无法轻易建立“二级索引”,难以执行求和、计数、排序等操作。比如,在旧版本的(<0.92)Hbase中,统计数据表的...

微笑向暖wx
32分钟前
1
0
【实践】如何获得Rinkeby网络的测试以太币

当把智能合约部署到Rinkeby Test Network时,需要获得测试以太币。其网络获取测试以太币的方法同Ropsten Test Network有些不同,本文详细讲解一下。 1 访问网站 访问rinkeby网络(https://w...

HiBlock
53分钟前
1
0
Logback中如何自定义灵活的日志过滤规则

当我们需要对日志的打印要做一些范围的控制的时候,通常都是通过为各个Appender设置不同的Filter配置来实现。在Logback中自带了两个过滤器实现:ch.qos.logback.classic.filter.LevelFilter...

程序猿DD
59分钟前
3
0
ES6中let 和 const 的新特性

在javascript中,我们都知道使用var来声明变量。javascript是函数级作用域,函数内可以访问函数外的变量,函数外不能访问函数内的变量。 ECMAScript 6 是 JavaScript 语言教程,全面介绍 EC...

peakedness丶
今天
2
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部