用中值排序基数法实现树状结构——让递归滚一边去

递归|排序

用中值排序基数法实现树状结构

    在BBS的编写中,经常有人问怎样实现树状结构?一个比较不负责任的回答是:使用递归算法。当然,递归是一个可行的办法(二叉树的历遍也好象只能使用递归算法),但对于BBS来说,这样做势必要进行大量的Sql查询(虽然可以使用存储过程来做,但要从根本上加快速度,则应该考虑更快的算法)。
下面给出一个可行的彻底屏弃递的实现树状结构的算法。

    下面给出另一种使用“使用中值排序基数法”实现树状结构:
一、主要思想:增加一个排序基数字段ordernum,回复同一根贴的贴子中插入贴子时,排序基数ordernum取两者的中值。
    为了叙述的简洁,在此只讨论与树状结构有关的字段。

在表中增加三个冗余字段,rootid——用于记录根id,deep——用于记录回复的深度(为0时表示根贴),ordernum——排序基数(关键所在)。

表forum与(只列与树状结构有关的字段):
id   rootid   deep    ordernum
其中id、rootid、deep均为int型(deep可为tinyint型),ordernum为float型。

例:(在此为了简单,使用一个小的起始排序基数,在实际应用中,应使用较大的起始基数,且应取2的整数次幂,如65536=2^16,下面所说的排序均指按ordernum从小到大排序)。
id   rootid    deep    ordernum
1      0        0            0
2      1        1           64
______________________________
3      1        1           32    回复第1贴,取1、2基数的中值即(0+64)/2

排序后结果为:
id   rootid    deep    ordernum
1      0        0            0
3      1        1           32
2      1        1           64
______________________________
4      1        2           48   回复第3贴,取3、2的基数中值即(32+64)/2

排序后结果为:
id   rootid    deep    ordernum
1      0        0            0
3      1        1           32
4      1        2           48
2      1        1           64
______________________________
5      1        3           56  回复第4贴,取4、2的基数中值即(48+64)/2

排序后的结果为:
id   rootid    deep    ordernum
1      0        0            0
3      1        1           32
4      1        2           48
5      1        3           56
2      1        1           64
______________________________
6      1        2           40  回复第3贴,取3、4的基数中值即(32+48)/2

排序后的结果为:
id   rootid    deep    ordernum
1      0        0            0
3      1        1           32
6&nb

时间: 2024-12-30 18:02:36

用中值排序基数法实现树状结构——让递归滚一边去的相关文章

“中值排序基数法实现树状结构”的补充

排序 "中值排序基数法实现树状结构"的补充     由于一时疏忽,造成了此法"对于int类型的基数字段,对原始贴的回复只能有31个:numeric类型的基数字段,对原始贴的回复也不能超过120个"(实际上是对于int型字段,原始贴的回复第32个以上的树状结构显示开始紊乱,对于numeric型的基数字段,原始贴的回复从121个以上树状结构显示开始紊乱--回复并不会出问题),这是由于计算机存储精度引起的.    我们可以将加贴的存储过程修改一下(加进前面加上**号的行)

使用多中值排序基数实现大型树状结构

排序 使用多中值排序基数实现大型树状结构     在"中值排序基数法实现树状结构"中,为了解决回复限制的问题,我们可以增加第二(三.四--)基数字段.    其实在一般的BBS中,使用一个基数已经足够,因为一个贴子的回复太多或深度太大的时候,无论你的树状结构做得多好,由于屏幕的限制(显示折行),显示总会乱,因此不如象在<补充>一文中,达到一定深度或个数时,后面的贴子采用平行显示的方法,不过那部分已经不再是树状结构了.    原理:在贴子显示的order by子句中,如果排序

使用“使用中值排序基数法”实现树状结构(一)

排序|排序 在BBS的编写中,经常有人问怎样实现树状结构?一个比较不负责任的回答是:使用递归算法.当然,递归是一个可行的办法(二叉树的历遍也好象只能使用递归算法),但对于BBS来说,这样做势必要进行大量的Sql查询(虽然可以使用存储过程来做,但要从根本上加快速度,则应该考虑更快的算法). 下面给出一个可行的彻底屏弃递的实现树状结构的算法. 下面给出另一种使用"使用中值排序基数法"实现树状结构: 一.主要思想:增加一个排序基数字段ordernum,回复同一根贴的贴子中插入贴子时,排序

使用“使用中值排序基数法”实现树状结构(二)

实现原理:以一排序字段(字符型实现排序),该字段的实际长度即为回复深度(用一位字符代表一层深度时). 所受限制:回复深度只受排序串定义长度的限制(有点象空间换深度),每贴回复数(包括根贴和子贴)为30左右(当sql server使用Dictionary order,case-insensitive排序方式,即不区分字母大小写时),如果sql server使用Binary orders排序方式时受限为127(255?). 改进方法:如果觉得不够用,可以使用多位字符对应一个深度(这样计算有点麻烦),

用排序串字段实现树状结构(原理)

排序     实现原理:以一排序字段(字符型实现排序),该字段的实际长度即为回复深度(用一位字符代表一层深度时).    所受限制:回复深度只受排序串定义长度的限制(有点象空间换深度),每贴回复数(包括根贴和子贴)为30左右(当sql server使用Dictionary order,case-insensitive排序方式,即不区分字母大小写时),如果sql server使用Binary orders排序方式时受限为127(255?).    改进方法:如果觉得不够用,可以使用多位字符对应一个

用排序串字段实现树状结构(库结构)

排序 以下是建立库结构的Sql语句(以一个简单的树状留言薄为例): if exists(select * from sysobjects where ID = object_id("guestbook"))  drop table guestbookgodrop table guestbookcreate table guestbook(  lybid int identity(1,1),  guestname varchar(40) NOT NULL,  guestitle varc

用排序串字段实现树状结构(例程——显示树)

排序|显示 程序index.asp功能:显示目录树 <!-- #include file="lybcon.inc" --><%pageno=request("pageno")searchtype=request("searchtype")searchnr=rtrim(request("searchnr"))set guestconn=Server.CreateObject("ADODB.connec

用排序串字段实现树状结构(例程——连接字串)

排序 程序名称:lybcon.inc程序功能:数据库连接字符串 <%lybstr="Provider=SQLOLEDB.1;Password=密码;Persist Security Info=True;User ID=sa;Initial Catalog=数据库名;Data Source=数据库服务器名;Connect Timeout=15" %>注意:一时疏忽,请使用.asp作为连接字符串文件名--有些服务器没有为.inc文件指定对应的映射,从而可以看到.inc的文件内容

用排序串字段实现树状结构(例程——回复表单)

排序 程序名称:revert.asp程序功能:回复表单 <!-- #include file="lybcon.inc" --><%pageno=request("pageno")keyid=request("keyid")posttype=request("type")if posttype="revert" then  set guestconn=Server.CreateObject(