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

数据结构与算法(C#实现)系列---广义树(一) (转)[@more@]

  数据结构与算法(C#实现)系列---广义树(一)XML:namespace prefix = o ns = "urn:schemas-microsoft-com:Office:office" />

  Heavenkiller(原创)

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

using System;

using System.Collections;

namespace DataStructure

{

  ///

  /// GeneralTree 的摘要说明。

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

  /// use ArrayList to replace ListAsLinkedList

  ///

  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;

  }

  }


来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/10794571/viewspace-974270/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/10794571/viewspace-974270/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值