手机站
网通分站
电信主站
密 码:
用户名:
当前位置 : 主页>程序设计>C/C++>列表

数据结构和算法(c#实现)系列---广义树(一)_c#教程

来源:互联网 作者:west263.com 时间:2008-02-23
西部数码-全国虚拟主机10强!40余项虚拟主机管理功能,全国领先!双线多线虚拟主机南北访问畅通无阻!免费赠送企业邮局,.CN域名,自助建站480元起,免费试用7天,满意再付款! P4主机租用799元/月.月付免压金!

数据结构和算法(C#实现)系列---广义树(一)

Heavenkiller(原创)

广义树和基本树的主要区别就是有任意的度

using System;
using System.Collections;
namespace DataStructure

{
/// <summary>

/// GeneralTree 的摘要说明。

/// general tree is a tree which has a arbitrary degree and no empty tree

/// use ArrayList to replace ListAsLinkedList

/// </summary>

public class GeneralTree:Tree

{

protected object key=null;

protected uint degree=0;

//protected uint height=0;

protected ArrayList treeList=new ArrayList();

public GeneralTree(object _objKey)

{

//

// TODO: 在此处添加构造函数逻辑

//

key=_objKey;

degree=0;

// height=0;

ArrayList treeList=new ArrayList();

}

public virtual void AttackSubtree(GeneralTree _gTree)

{

this.treeList.Add(_gTree);

degree;

}

public virtual GeneralTree DetachSubtree(GeneralTree _gTree)

{

this.treeList.Remove(_gTree);

degree--;

return _gTree;//????? how to remove ,reference or object????

}

public override Tree this[uint _index]

{

get

{

if(_index>=this.degree)

throw new Exception("my:out of index");

return (Tree)treeList[(int)_index];

}

set

{
treeList[(int)_index]=value;

}
}


文章整理:西部数码--专业提供域名注册虚拟主机服务
http://www.west263.com
以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!