分类算法要解决的问题

分类算法要解决的问题

ID:40483003

大小:53.00 KB

页数:6页

时间:2019-08-03

分类算法要解决的问题_第1页
分类算法要解决的问题_第2页
分类算法要解决的问题_第3页
分类算法要解决的问题_第4页
分类算法要解决的问题_第5页
资源描述:

《分类算法要解决的问题》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、分类算法要解决的问题在网站建设中,分类算法的应用非常的普遍。在设计一个电子商店时,要涉及到商品分类;在设计发布系统时,要涉及到栏目或者频道分类;在设计软件下载这样的程序时,要涉及到软件的分类;如此等等。可以说,分类是一个很普遍的问题。1、分类算法常常表现为树的表示和遍历问题。那么,请问:如果用数据库中的一个Table来表达树型分类,应该有几个字段?2、如何快速地从这个Table恢复出一棵树;3、如何判断某个分类是否是另一个分类的子类;4、如何查找某个分类的所有产品;5、如何生成分类所在的路径。6、如何新增分类;在不限制分类

2、的级数和每级分类的个数时,这些问题并不是可以轻松回答的。本文试图解决这些问题。分类的数据结构我们知道:分类的数据结构实际上是一棵树。在《数据结构》课程中,大家可能学过Tree的算法。由于在网站建设中我们大量使用数据库,所以我们将从Tree在数据库中的存储谈起。为简化问题,我们假设每个节点只需要保留Name这一个信息。我们需要为每个节点编号。编号的方法有很多种。在数据库中常用的就是自动编号。这在Access、SQLServer、Oracle中都是这样。假设编号字段为ID。为了表示某个节点ID1是另外一个节点ID2的父节点,我

3、们需要在数据库中再保留一个字段,说明这个分类是属于哪个节点的儿子。把这个字段取名为FatherID。如这里的ID2,其FatherID就是ID1。这样,我们就得到了分类Catalog的数据表定义:CreateTable[Catalog]([ID][int]NOTNULL,[Name][nvarchar](50)NOTNULL,[FatherID][int]NOTNULL);约定:我们约定用-1作为最上面一层分类的父亲编码。编号为-1的分类。这是一个虚拟的分类。它在数据库中没有记录。如何恢复出一棵树上面的Catalog定义的

4、最大优势,就在于用它可以轻松地恢复出一棵树—分类树。为了更清楚地展示算法,我们先考虑一个简单的问题:怎样显示某个分类的下一级分类。我们知道,要查询某个分类FID的下一级分类,SQL语句非常简单:selectNamefromcatalogwhereFatherID=FID显示这些类别时,我们简单地用

  • 来做到:<%REMoConn---数据库连接,调用GetChildren时已经打开REMFID-----当前分类的编号FunctionGetChildren(oConn,FID)strSQL="selectID,Namef

    5、romcatalogwhereFatherID="&FIDsetrsCatalog=oConn.Execute(strSQL)%>

      <%DowhilenotrsCatalog.Eof%>
    • <%=rsCatalog("Name")%><%Loop%>
    <%rsCatalog.CloseEndFunction%>现在我们来看看如何显示FID下的所有分类。这需要用到递归算法。我们只需要在GetChildren函数中简单地对所有ID进行调用:GetChildren(oConn,Catalog(“ID”))就可以

    6、了。<%REMoConn---数据库连接,已经打开REMFID-----当前分类的编号FunctionGetChildren(oConn,FID)strSQL="selectNamefromcatalogwhereFatherID="&FIDsetrsCatalog=oConn.Execute(strSQL)%>

      <%DowhilenotrsCatalog.Eof%>
    • <%=rsCatalog("Name")%><%=GetChildren(oConn,Catalog("ID"))%><%Loop%>

    7、<%rsCatalog.CloseEndFunction%>修改后的GetChildren就可以完成显示FID分类的所有子分类的任务。要显示所有的分类,只需要如此调用就可以了:<%REMstrConn--连接数据库的字符串,请根据情况修改setoConn=Server.CreateObject("ADODB.Connection")oConn.OpenstrConn=GetChildren(oConn,-1)oConn.Close%>如何查找某个分类的所有产品;现在来解决我们在前面提出的第四个问题。第三个问题留作习题。我们

    8、假设产品的数据表如下定义:CreateTableProduct([ID][int]NOTNULL,[Name][nvchar]NOTNULL,[FatherID][int]NOTNULL);其中,ID是产品的编号,Name是产品的名称,而FatherID是产品所属的分类。对第四个问题,很容易想到的办法是

  • 当前文档最多预览五页,下载文档查看全文

    此文档下载收益归作者所有

    当前文档最多预览五页,下载文档查看全文
    温馨提示:
    1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
    2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
    3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
    4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。