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

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

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

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

Heavenkiller(原创)

public class InOrder:IPrePostVisitor

{

private IVisitor visitor;

public InOrder(IVisitor _vis){visitor=_vis;}

#region IPrePostVisitor 成员

public void PreVisit(object _obj)

{

// TODO: 添加 InOrder.PreVisit 实现

}

public void Visit(object _obj)

{

// TODO: 添加 InOrder.Visit 实现

this.visitor.Visit(_obj);

}

public void PostVisit(object _obj)

{

// TODO: 添加 InOrder.PostVisitor 实现

}

#endregion

}

public class PostOrder:IPrePostVisitor

{

private IVisitor visitor;

public PostOrder(IVisitor _vis){visitor=_vis;}

#region IPrePostVisitor 成员

public void PreVisit(object _obj)

{

// TODO: 添加 PostOrder.PreVisit 实现

}

public void Visit(object _obj)

{

// TODO: 添加 PostOrder.Visit 实现

}

public void PostVisit(object _obj)

{

// TODO: 添加 PostOrder.PostVisitor 实现

this.visitor.Visit(_obj);

}

#endregion

}

protected class EnumVisitor:IVisitor

{

Queue thisQueue;

public EnumVisitor(Queue _que)

{

this.thisQueue=_que;

}

#region IVisitor 成员

public void Visit(object _obj)

{

// TODO: 添加 EnumVisitor.Visit 实现

this.thisQueue.Enqueue(_obj);

}

#endregion

}

#region IEnumerable 成员

public IEnumerator GetEnumerator()

{

// TODO: 添加 Tree.GetEnumerator 实现

EnumVisitor vis=new EnumVisitor(this.keyqueue);

switch (this.traversaltype)

{

case TraversalType.Breadth:

BreadthFirstTraversal(vis);

break;

case TraversalType.PreDepth:

PreOrder preVis=new PreOrder(vis);

DepthFirstTraversal(preVis);

break;

case TraversalType.InDepth:

InOrder inVis=new InOrder(vis);

DepthFirstTraversal(inVis);

break;

case TraversalType.PostDepth:

PostOrder postVis=new PostOrder(vis);

DepthFirstTraversal(postVis);

break;

default:

Console.WriteLine("WARNING:please set a travel type first!--void SetTraversalType(TraversalType _type) ");

//throw new Exception("WARNING:please set a travel type first!");//if not set a type, a exception will happen

break;

}

return this.keyqueue.GetEnumerator();

}

#endregion


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